Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
京东前端
nutui-react
提交
a902a017
N
nutui-react
项目概览
京东前端
/
nutui-react
通知
0
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
N
nutui-react
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
未验证
提交
a902a017
编写于
3月 20, 2023
作者:
liu_zheng_wu
提交者:
GitHub
3月 20, 2023
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix: ellipsis 组件动态设置内容无效问题 (#823)
上级
4d5891cc
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
15 addition
and
6 deletion
+15
-6
src/packages/ellipsis/ellipsis.taro.tsx
src/packages/ellipsis/ellipsis.taro.tsx
+15
-6
未找到文件。
src/packages/ellipsis/ellipsis.taro.tsx
浏览文件 @
a902a017
import
React
,
{
FunctionComponent
,
useState
,
useRef
}
from
'
react
'
import
React
,
{
FunctionComponent
,
useState
,
useRef
,
useEffect
}
from
'
react
'
import
{
useReady
,
nextTick
,
createSelectorQuery
}
from
'
@tarojs/taro
'
import
{
useConfig
}
from
'
@/packages/configprovider/configprovider.taro
'
import
{
getRectByTaro
}
from
'
@/utils/useClientRect
'
...
...
@@ -58,7 +58,7 @@ export const Ellipsis: FunctionComponent<
const
root
=
useRef
<
HTMLDivElement
>
(
null
)
const
rootContain
=
useRef
<
HTMLDivElement
>
(
null
)
const
symbolContain
=
useRef
<
HTMLDivElement
>
(
null
)
const
contantCopy
:
any
=
useRef
(
content
)
const
[
contentCopy
,
setContentCopy
]
=
useState
(
content
)
let
lineH
=
0
// 当行的最大高度
let
originHeight
=
0
// 原始高度
const
refRandomId
=
Math
.
random
().
toString
(
36
).
slice
(
-
8
)
...
...
@@ -70,12 +70,19 @@ export const Ellipsis: FunctionComponent<
const
letterUpperReg
=
/^
[
A-Z
]
+$/
// 字母
const
letterLowerReg
=
/^
[
a-z
]
+$/
// 字母
useReady
(()
=>
{
const
init
=
()
=>
{
setExceeded
(
false
)
setExpanded
(
false
)
setContentCopy
(
content
)
nextTick
(()
=>
{
getSymbolInfo
()
getReference
()
})
})
}
useReady
(()
=>
init
())
useEffect
(()
=>
init
(),
[
content
])
// 获取省略号宽度
const
getSymbolInfo
=
async
()
=>
{
...
...
@@ -111,6 +118,7 @@ export const Ellipsis: FunctionComponent<
],
},
(
res
)
=>
{
if
(
!
res
)
return
lineH
=
pxToNumber
(
res
.
lineHeight
===
'
normal
'
?
lineHeight
:
res
.
lineHeight
)
...
...
@@ -201,11 +209,12 @@ export const Ellipsis: FunctionComponent<
}
}
const
assignContent
=
()
=>
{
con
tantCopy
.
curr
ent
=
`
${
ellipsis
.
current
?.
leading
||
''
}${
con
st
newCont
ent
=
`
${
ellipsis
.
current
?.
leading
||
''
}${
ellipsis
.
current
?.
leading
?
symbol
:
''
}${
expandText
||
''
}${
ellipsis
.
current
?.
tailing
?
symbol
:
''
}${
ellipsis
.
current
?.
tailing
||
''
}
`
setContentCopy
(
newContent
)
}
// 计算省略号
const
tailorContent
=
(
left
:
number
,
right
:
number
,
type
=
''
)
=>
{
...
...
@@ -336,7 +345,7 @@ export const Ellipsis: FunctionComponent<
id
=
{
`rootContain
${
refRandomId
}
`
}
style
=
{
{
width
:
`
${
widthRef
}
`
}
}
>
<
div
>
{
cont
antCopy
.
current
}
</
div
>
<
div
>
{
cont
entCopy
}
</
div
>
</
div
>
<
div
className
=
"nut-ellipsis-copy"
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录