/*! For license information please see 8724.33adf146.js.LICENSE.txt */ (self.webpackChunk=self.webpackChunk||[]).push([["8724"],{35213:function(s,n,a){"use strict";a.r(n);var t=a("80681");let l=["innerHTML"];n.default={setup:()=>({html:""}),render:()=>((0,t.wg)(),(0,t.iD)("div",{class:"van-doc-markdown-body",innerHTML:'
\u7528\u4E8E\u5728\u6253\u5F00\u548C\u5173\u95ED\u72B6\u6001\u4E4B\u95F4\u8FDB\u884C\u5207\u6362\u3002
\n\u901A\u8FC7\u4EE5\u4E0B\u65B9\u5F0F\u6765\u5168\u5C40\u6CE8\u518C\u7EC4\u4EF6\uFF0C\u66F4\u591A\u6CE8\u518C\u65B9\u5F0F\u8BF7\u53C2\u8003\u7EC4\u4EF6\u6CE8\u518C\u3002
\nimport { createApp } from 'vue';\nimport { Switch } from 'vant';\n\nconst app = createApp();\napp.use(Switch);\n
\n\u901A\u8FC7 v-model
\u7ED1\u5B9A\u5F00\u5173\u7684\u9009\u4E2D\u72B6\u6001\uFF0Ctrue
\u8868\u793A\u5F00\uFF0Cfalse
\u8868\u793A\u5173\u3002
<van-switch v-model="checked" />\n
\nimport { ref } from 'vue';\n\nexport default {\n setup() {\n const checked = ref(true);\n return { checked };\n },\n};\n
\n\u901A\u8FC7 disabled
\u5C5E\u6027\u6765\u7981\u7528\u5F00\u5173\uFF0C\u7981\u7528\u72B6\u6001\u4E0B\u5F00\u5173\u4E0D\u53EF\u70B9\u51FB\u3002
<van-switch v-model="checked" disabled />\n
\n\u901A\u8FC7 loading
\u5C5E\u6027\u8BBE\u7F6E\u5F00\u5173\u4E3A\u52A0\u8F7D\u72B6\u6001\uFF0C\u52A0\u8F7D\u72B6\u6001\u4E0B\u5F00\u5173\u4E0D\u53EF\u70B9\u51FB\u3002
<van-switch v-model="checked" loading />\n
\n\u901A\u8FC7 size
\u5C5E\u6027\u81EA\u5B9A\u4E49\u5F00\u5173\u7684\u5927\u5C0F\u3002
<van-switch v-model="checked" size="22px" />\n
\nactive-color
\u5C5E\u6027\u8868\u793A\u6253\u5F00\u65F6\u7684\u80CC\u666F\u8272\uFF0Cinactive-color
\u8868\u793A\u5173\u95ED\u65F6\u7684\u80CC\u666F\u8272\u3002
<van-switch v-model="checked" active-color="#ee0a24" inactive-color="#dcdee0" />\n
\n\u901A\u8FC7 node
\u63D2\u69FD\u81EA\u5B9A\u4E49\u6309\u94AE\u7684\u5185\u5BB9\u3002
<van-switch v-model="checked">\n <template #node>\n <div class="icon-wrapper">\n <van-icon :name="checked ? 'success' : 'cross'" />\n </div>\n </template>\n</van-switch>\n\n<style>\n .icon-wrapper {\n display: flex;\n width: 100%;\n justify-content: center;\n font-size: 18px;\n }\n\n .icon-wrapper .van-icon-success {\n line-height: 32px;\n color: var(--van-blue);\n }\n\n .icon-wrapper .van-icon-cross {\n line-height: 32px;\n color: var(--van-gray-5);\n }\n</style>\n
\n\u9700\u8981\u5F02\u6B65\u63A7\u5236\u5F00\u5173\u65F6\uFF0C\u53EF\u4EE5\u4F7F\u7528 modelValue
\u5C5E\u6027\u548C update:model-value
\u4E8B\u4EF6\u4EE3\u66FF v-model
\uFF0C\u5E76\u5728\u4E8B\u4EF6\u56DE\u8C03\u51FD\u6570\u4E2D\u624B\u52A8\u5904\u7406\u5F00\u5173\u72B6\u6001\u3002
<van-switch :model-value="checked" @update:model-value="onUpdateValue" />\n
\nimport { ref } from 'vue';\nimport { showConfirmDialog } from 'vant';\n\nexport default {\n setup() {\n const checked = ref(true);\n const onUpdateValue = (newValue) => {\n showConfirmDialog({\n title: '\u63D0\u9192',\n message: '\u662F\u5426\u5207\u6362\u5F00\u5173\uFF1F',\n }).then(() => {\n checked.value = newValue;\n });\n };\n\n return {\n checked,\n onUpdateValue,\n };\n },\n};\n
\n<van-cell center title="\u6807\u9898">\n <template #right-icon>\n <van-switch v-model="checked" />\n </template>\n</van-cell>\n
\n\u53C2\u6570 | \n\u8BF4\u660E | \n\u7C7B\u578B | \n\u9ED8\u8BA4\u503C | \n
---|---|---|---|
v-model | \n\u5F00\u5173\u9009\u4E2D\u72B6\u6001 | \nany | \nfalse | \n
loading | \n\u662F\u5426\u4E3A\u52A0\u8F7D\u72B6\u6001 | \nboolean | \nfalse | \n
disabled | \n\u662F\u5426\u4E3A\u7981\u7528\u72B6\u6001 | \nboolean | \nfalse | \n
size | \n\u5F00\u5173\u6309\u94AE\u7684\u5C3A\u5BF8\uFF0C\u9ED8\u8BA4\u5355\u4F4D\u4E3A px | \nnumber | string | \n26px | \n
active-color | \n\u6253\u5F00\u65F6\u7684\u80CC\u666F\u8272 | \nstring | \n#1989fa | \n
inactive-color | \n\u5173\u95ED\u65F6\u7684\u80CC\u666F\u8272 | \nstring | \nrgba(120, 120, 128, 0.16) | \n
active-value | \n\u6253\u5F00\u65F6\u5BF9\u5E94\u7684\u503C | \nany | \ntrue | \n
inactive-value | \n\u5173\u95ED\u65F6\u5BF9\u5E94\u7684\u503C | \nany | \nfalse | \n
\u4E8B\u4EF6\u540D | \n\u8BF4\u660E | \n\u56DE\u8C03\u53C2\u6570 | \n
---|---|---|
change | \n\u5F00\u5173\u72B6\u6001\u5207\u6362\u65F6\u89E6\u53D1 | \nvalue: any | \n
click | \n\u70B9\u51FB\u65F6\u89E6\u53D1 | \nevent: MouseEvent | \n
\u540D\u79F0 | \n\u8BF4\u660E | \n\u53C2\u6570 | \n
---|---|---|
node | \n\u81EA\u5B9A\u4E49\u6309\u94AE\u7684\u5185\u5BB9 | \n- | \n
background | \n\u81EA\u5B9A\u4E49\u5F00\u5173\u7684\u80CC\u666F\u5185\u5BB9 | \n- | \n
\u7EC4\u4EF6\u5BFC\u51FA\u4EE5\u4E0B\u7C7B\u578B\u5B9A\u4E49\uFF1A
\nimport type { SwitchProps } from 'vant';\n
\n\u7EC4\u4EF6\u63D0\u4F9B\u4E86\u4E0B\u5217 CSS \u53D8\u91CF\uFF0C\u53EF\u7528\u4E8E\u81EA\u5B9A\u4E49\u6837\u5F0F\uFF0C\u4F7F\u7528\u65B9\u6CD5\u8BF7\u53C2\u8003 ConfigProvider \u7EC4\u4EF6\u3002
\n\u540D\u79F0 | \n\u9ED8\u8BA4\u503C | \n\u63CF\u8FF0 | \n
---|---|---|
--van-switch-size | \n26px | \n- | \n
--van-switch-width | \ncalc(1.8em + 4px) | \n- | \n
--van-switch-height | \ncalc(1em + 4px) | \n- | \n
--van-switch-node-size | \n1em | \n- | \n
--van-switch-node-background | \nvar(--van-white) | \n- | \n
--van-switch-node-shadow | \n0 3px 1px 0 rgba(0, 0, 0, 0.05) | \n- | \n
--van-switch-background | \nrgba(120, 120, 128, 0.16) | \n- | \n
--van-switch-on-background | \nvar(--van-primary-color) | \n- | \n
--van-switch-duration | \nvar(--van-duration-base) | \n- | \n
--van-switch-disabled-opacity | \nvar(--van-disabled-opacity) | \n- | \n