Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
uni-app
提交
6494c8a7
U
uni-app
项目概览
DCloud
/
uni-app
3 个月 前同步成功
通知
725
Star
38705
Fork
3642
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
7
列表
看板
标记
里程碑
合并请求
1
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
uni-app
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
7
Issue
7
列表
看板
标记
里程碑
合并请求
1
合并请求
1
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
6494c8a7
编写于
2月 23, 2022
作者:
d-u-a
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(nvue3): slider 支持 form,设置 min/max 出现计算错误问题
上级
4d456bae
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
30 addition
and
1 deletion
+30
-1
packages/uni-components/src/nvue/slider/index.tsx
packages/uni-components/src/nvue/slider/index.tsx
+30
-1
未找到文件。
packages/uni-components/src/nvue/slider/index.tsx
浏览文件 @
6494c8a7
...
...
@@ -5,6 +5,8 @@ import {
computed
,
watch
,
onMounted
,
onUnmounted
,
inject
,
reactive
,
ExtractPropTypes
,
}
from
'
vue
'
...
...
@@ -15,6 +17,7 @@ import {
}
from
'
../../helpers/useNVueEvent
'
import
{
getComponentSize
}
from
'
../helpers
'
import
{
NVueComponentStyles
,
createNVueTextVNode
}
from
'
../utils
'
import
{
uniFormKey
,
UniFormCtx
}
from
'
../../components/form
'
import
{
sliderProps
}
from
'
../../components/slider
'
const
slierStyles
:
NVueComponentStyles
=
[
...
...
@@ -121,6 +124,7 @@ export default defineComponent({
const
state
=
useSliderState
(
props
)
const
listeners
=
useSliderListeners
(
props
,
state
,
trigger
)
useSliderInject
(
props
,
state
)
watch
(
()
=>
props
.
value
,
...
...
@@ -187,7 +191,7 @@ function useSliderState(props: SliderProps) {
const
_getValueWidth
=
()
=>
{
const
max
=
Number
(
props
.
max
)
const
min
=
Number
(
props
.
min
)
return
((
sliderValue
.
value
-
min
)
/
max
-
min
)
*
sliderWidth
.
value
return
((
sliderValue
.
value
-
min
)
/
(
max
-
min
)
)
*
sliderWidth
.
value
}
const
state
=
reactive
({
...
...
@@ -274,3 +278,28 @@ function useSliderListeners(
return
listeners
}
function
useSliderInject
(
props
:
SliderProps
,
state
:
SliderState
)
{
const
uniForm
=
inject
<
UniFormCtx
>
(
uniFormKey
,
false
as
unknown
as
UniFormCtx
)
const
formField
=
{
submit
:
()
=>
{
const
data
:
[
string
,
any
]
=
[
''
,
null
]
if
(
props
.
name
)
{
data
[
0
]
=
props
.
name
data
[
1
]
=
state
.
sliderValue
}
return
data
},
reset
:
()
=>
{
state
.
sliderValue
=
Number
(
props
.
value
)
},
}
if
(
!!
uniForm
)
{
uniForm
.
addField
(
formField
)
onUnmounted
(()
=>
{
uniForm
.
removeField
(
formField
)
})
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录