//加载动画@keyframesrotate{from{transform:rotate(0deg);}到{变换:旋转(360deg);}}//switchstyle.sun-switch{position:relative;显示:内联块;框大小:内容框;宽度:2em;高度:1em;字体大小:30px;背景色:#fff;border:1pxsolidrgba(0,0,0,0.1);边界半径:1em;游标:指针;过渡:背景色0.3s;}//内圈按钮style.sun-switch-node{display:flex;证明内容:居中;对齐项目:居中;位置:绝对;顶部:0;左:0;z-索引:1;宽度:1em;高度:1em;背景色:#fff;边界半径:100%;框阴影:03px1px0rgba(0,0,0,0.05),02px2px0rgba(0,0,0,0.1),03px3px0rgba(0,0,0,0.05);过渡:变换0.3秒立方贝塞尔曲线(0.3、1.05、0.4、1.05),-webkit变换0.3秒立方贝塞尔曲线(0.3、1.05、0.4、1.05);.sun-icon-loading{动画:旋转2s无限线性;字体大小:0.6em;}}//选中style.sun-switch-on{background-color:#1989fa;.sun-switch-node{转换:translateX(1em);.sun-icon-loading{动画:旋转2s无限线性;颜色:#1989fa;}}}.sun-switch-disabled{光标:不允许;不透明度:0.5;}组件封装代码components/switch/switch.vue