Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Simoje丶
vue-vben-admin
提交
5b4a41ce
V
vue-vben-admin
项目概览
Simoje丶
/
vue-vben-admin
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
vue-vben-admin
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
5b4a41ce
编写于
3月 26, 2021
作者:
V
Vben
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat(api-select): add immediate option,close #430
上级
e090689e
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
151 addition
and
5 deletion
+151
-5
src/components/Form/src/components/ApiSelect copy.vue
src/components/Form/src/components/ApiSelect copy.vue
+127
-0
src/components/Form/src/components/ApiSelect.vue
src/components/Form/src/components/ApiSelect.vue
+24
-5
未找到文件。
src/components/Form/src/components/ApiSelect copy.vue
0 → 100644
浏览文件 @
5b4a41ce
<
template
>
<Select
v-bind=
"attrs"
:options=
"getOptions"
v-model:value=
"state"
@
focus=
"handleFetch"
>
<template
#[item]=
"data"
v-for=
"item in Object.keys($slots)"
>
<slot
:name=
"item"
v-bind=
"data"
></slot>
</
template
>
<
template
#suffixIcon
v-if=
"loading"
>
<LoadingOutlined
spin
/>
</
template
>
<
template
#notFoundContent
v-if=
"loading"
>
<span>
<LoadingOutlined
spin
class=
"mr-1"
/>
{{
t
(
'
component.form.apiSelectNotFound
'
)
}}
</span>
</
template
>
</Select>
</template>
<
script
lang=
"ts"
>
import
{
defineComponent
,
PropType
,
ref
,
watchEffect
,
computed
,
unref
}
from
'
vue
'
;
import
{
Select
}
from
'
ant-design-vue
'
;
import
{
isFunction
}
from
'
/@/utils/is
'
;
import
{
useRuleFormItem
}
from
'
/@/hooks/component/useFormItem
'
;
import
{
useAttrs
}
from
'
/@/hooks/core/useAttrs
'
;
import
{
get
}
from
'
lodash-es
'
;
import
{
LoadingOutlined
}
from
'
@ant-design/icons-vue
'
;
import
{
useI18n
}
from
'
/@/hooks/web/useI18n
'
;
import
{
propTypes
}
from
'
/@/utils/propTypes
'
;
type
OptionsItem
=
{
label
:
string
;
value
:
string
;
disabled
?:
boolean
};
export
default
defineComponent
({
name
:
'
ApiSelect
'
,
components
:
{
Select
,
LoadingOutlined
,
},
inheritAttrs
:
false
,
props
:
{
value
:
propTypes
.
string
,
numberToString
:
propTypes
.
bool
,
api
:
{
type
:
Function
as
PropType
<
(
arg
?:
Recordable
)
=>
Promise
<
OptionsItem
[]
>>
,
default
:
null
,
},
// api params
params
:
{
type
:
Object
as
PropType
<
Recordable
>
,
default
:
()
=>
{},
},
// support xxx.xxx.xx
resultField
:
propTypes
.
string
.
def
(
''
),
labelField
:
propTypes
.
string
.
def
(
'
label
'
),
valueField
:
propTypes
.
string
.
def
(
'
value
'
),
immediate
:
propTypes
.
bool
.
def
(
true
),
},
emits
:
[
'
options-change
'
,
'
change
'
],
setup
(
props
,
{
emit
})
{
const
options
=
ref
<
OptionsItem
[]
>
([]);
const
loading
=
ref
(
false
);
const
isFirstLoad
=
ref
(
true
);
const
attrs
=
useAttrs
();
const
{
t
}
=
useI18n
();
// Embedded in the form, just use the hook binding to perform form verification
const
[
state
]
=
useRuleFormItem
(
props
);
const
getOptions
=
computed
(()
=>
{
const
{
labelField
,
valueField
,
numberToString
}
=
props
;
return
unref
(
options
).
reduce
((
prev
,
next
:
Recordable
)
=>
{
if
(
next
)
{
const
value
=
next
[
valueField
];
prev
.
push
({
label
:
next
[
labelField
],
value
:
numberToString
?
`
${
value
}
`
:
value
,
});
}
return
prev
;
},
[]
as
OptionsItem
[]);
});
watchEffect
(()
=>
{
if
(
isFirstLoad
.
value
)
{
props
.
immediate
&&
fetch
();
}
else
{
fetch
();
}
});
async
function
fetch
()
{
const
api
=
props
.
api
;
if
(
!
api
||
!
isFunction
(
api
))
return
;
try
{
loading
.
value
=
true
;
const
res
=
await
api
(
props
.
params
);
if
(
Array
.
isArray
(
res
))
{
options
.
value
=
res
;
emitChange
();
return
;
}
if
(
props
.
resultField
)
{
options
.
value
=
get
(
res
,
props
.
resultField
)
||
[];
}
emitChange
();
}
catch
(
error
)
{
console
.
warn
(
error
);
}
finally
{
loading
.
value
=
false
;
}
}
async
function
handleFetch
()
{
if
(
!
props
.
immediate
)
{
await
fetch
();
}
isFirstLoad
.
value
=
false
;
}
function
emitChange
()
{
emit
(
'
options-change
'
,
unref
(
options
));
}
return
{
state
,
attrs
,
getOptions
,
loading
,
t
,
handleFetch
};
},
});
</
script
>
src/components/Form/src/components/ApiSelect.vue
浏览文件 @
5b4a41ce
<
template
>
<Select
v-bind=
"attrs"
:options=
"getOptions"
v-model:value=
"state"
>
<Select
@
dropdownVisibleChange=
"handleFetch"
v-bind=
"attrs"
:options=
"getOptions"
v-model:value=
"state"
>
<template
#[item]=
"data"
v-for=
"item in Object.keys($slots)"
>
<slot
:name=
"item"
v-bind=
"data"
></slot>
</
template
>
...
...
@@ -51,11 +56,13 @@
resultField
:
propTypes
.
string
.
def
(
''
),
labelField
:
propTypes
.
string
.
def
(
'
label
'
),
valueField
:
propTypes
.
string
.
def
(
'
value
'
),
immediate
:
propTypes
.
bool
.
def
(
true
),
},
emits
:
[
'
options-change
'
,
'
change
'
],
setup
(
props
,
{
emit
})
{
const
options
=
ref
<
OptionsItem
[]
>
([]);
const
loading
=
ref
(
false
);
const
isFirstLoad
=
ref
(
true
);
const
attrs
=
useAttrs
();
const
{
t
}
=
useI18n
();
...
...
@@ -78,7 +85,7 @@
});
watchEffect
(()
=>
{
fetch
();
props
.
immediate
&&
fetch
();
});
async
function
fetch
()
{
...
...
@@ -90,20 +97,32 @@
const
res
=
await
api
(
props
.
params
);
if
(
Array
.
isArray
(
res
))
{
options
.
value
=
res
;
emit
(
'
options-change
'
,
unref
(
options
)
);
emit
Change
(
);
return
;
}
if
(
props
.
resultField
)
{
options
.
value
=
get
(
res
,
props
.
resultField
)
||
[];
}
emit
(
'
options-change
'
,
unref
(
options
)
);
emit
Change
(
);
}
catch
(
error
)
{
console
.
warn
(
error
);
}
finally
{
loading
.
value
=
false
;
}
}
return
{
state
,
attrs
,
getOptions
,
loading
,
t
};
async
function
handleFetch
()
{
if
(
!
props
.
immediate
&&
unref
(
isFirstLoad
))
{
await
fetch
();
isFirstLoad
.
value
=
false
;
}
}
function
emitChange
()
{
emit
(
'
options-change
'
,
unref
(
options
));
}
return
{
state
,
attrs
,
getOptions
,
loading
,
t
,
handleFetch
};
},
});
</
script
>
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录