mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-10-24 16:32:09 +08:00
feat: add switch
This commit is contained in:
parent
4562ca8b19
commit
72ea01032e
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
"sample": "./packages/sample/index.js",
|
"sample": "./packages/sample/index.js",
|
||||||
"button": "./packages/button/index.js"
|
"button": "./packages/button/index.js",
|
||||||
|
"switch": "./packages/switch/index.js"
|
||||||
}
|
}
|
||||||
|
80
docs/examples/switch.md
Normal file
80
docs/examples/switch.md
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
<script>
|
||||||
|
export default {
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
switchState: true
|
||||||
|
};
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
switchStateText() {
|
||||||
|
return this.switchState ? 'ON' : 'OFF';
|
||||||
|
}
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
updateState(newState) {
|
||||||
|
console.log('changing');
|
||||||
|
this.switchState = newState;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
<style lang="css">
|
||||||
|
@component-namespace page {
|
||||||
|
@component switch {
|
||||||
|
padding: 0 15px 15px;
|
||||||
|
|
||||||
|
@descendent sample {
|
||||||
|
margin: 0 15px;
|
||||||
|
}
|
||||||
|
|
||||||
|
@descendent text {
|
||||||
|
margin-right: 20px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
|
## Switch组件
|
||||||
|
|
||||||
|
### 基础用法
|
||||||
|
|
||||||
|
:::demo 样例代码
|
||||||
|
```html
|
||||||
|
<div class="page-switch">
|
||||||
|
<span class="page-switch-text">Switch state: {{switchStateText}}</span>
|
||||||
|
<o2-switch class="page-switch-sample" :checked="switchState" :onChange="updateState"></o2-switch>
|
||||||
|
<o2-switch class="page-switch-sample" :checked="false" :disabled="true"></o2-switch>
|
||||||
|
</div>
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
export default {
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
switchState: false
|
||||||
|
};
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
switchStateText() {
|
||||||
|
return this.switchState ? 'on' : 'off';
|
||||||
|
}
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
updateState(newState) {
|
||||||
|
console.log('changing');
|
||||||
|
this.switchState = newState;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
```
|
||||||
|
:::
|
||||||
|
|
||||||
|
### API
|
||||||
|
|
||||||
|
| 参数 | 说明 | 类型 | 默认值 | 可选值 |
|
||||||
|
|-----------|-----------|-----------|-------------|-------------|
|
||||||
|
| checked | 开关状态 | boolean | false | true,false |
|
||||||
|
| loading | loading状态 | boolean | false | true,false |
|
||||||
|
| disabled | 禁用状态 | boolean | false | true,false |
|
||||||
|
| onChange | 回调 | function | function(){} | - |
|
@ -13,6 +13,10 @@
|
|||||||
{
|
{
|
||||||
"path": "/button",
|
"path": "/button",
|
||||||
"title": "Button组件"
|
"title": "Button组件"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"path": "/switch",
|
||||||
|
"title": "Switch组件"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
@ -100,6 +100,7 @@
|
|||||||
"prismjs": "^1.5.1",
|
"prismjs": "^1.5.1",
|
||||||
"rimraf": "^2.5.4",
|
"rimraf": "^2.5.4",
|
||||||
"run-sequence": "^1.2.2",
|
"run-sequence": "^1.2.2",
|
||||||
|
"saladcss-bem":"^0.0.1",
|
||||||
"sass-loader": "^3.2.3",
|
"sass-loader": "^3.2.3",
|
||||||
"style-loader": "^0.13.1",
|
"style-loader": "^0.13.1",
|
||||||
"theaterjs": "^3.0.0",
|
"theaterjs": "^3.0.0",
|
||||||
|
0
packages/switch/CHANGELOG.md
Normal file
0
packages/switch/CHANGELOG.md
Normal file
26
packages/switch/README.md
Normal file
26
packages/switch/README.md
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
# @youzan/<%= name %>
|
||||||
|
|
||||||
|
!!! 请在此处填写你的文档最简单描述 !!!
|
||||||
|
|
||||||
|
[![version][version-image]][download-url]
|
||||||
|
[![download][download-image]][download-url]
|
||||||
|
|
||||||
|
[version-image]: http://npm.qima-inc.com/badge/v/@youzan/<%= name %>.svg?style=flat-square
|
||||||
|
[download-image]: http://npm.qima-inc.com/badge/d/@youzan/<%= name %>.svg?style=flat-square
|
||||||
|
[download-url]: http://npm.qima-inc.com/package/@youzan/<%= name %>
|
||||||
|
|
||||||
|
## Demo
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
|
||||||
|
## API
|
||||||
|
|
||||||
|
| 参数 | 说明 | 类型 | 默认值 | 可选值 |
|
||||||
|
|-----------|-----------|-----------|-------------|-------------|
|
||||||
|
| className | 自定义额外类名 | string | '' | '' |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## License
|
||||||
|
[MIT](https://opensource.org/licenses/MIT)
|
3
packages/switch/index.js
Normal file
3
packages/switch/index.js
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
import Switch from './src/switch';
|
||||||
|
|
||||||
|
export default Switch;
|
1
packages/switch/index.pcss
Normal file
1
packages/switch/index.pcss
Normal file
@ -0,0 +1 @@
|
|||||||
|
@import "./src/switch.pcss";
|
10
packages/switch/package.json
Normal file
10
packages/switch/package.json
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
{
|
||||||
|
"name": "@youzan/o2-switch",
|
||||||
|
"version": "0.0.1",
|
||||||
|
"description": "switch component",
|
||||||
|
"main": "./lib/index.js",
|
||||||
|
"author": "jiangruowei",
|
||||||
|
"license": "MIT",
|
||||||
|
"devDependencies": {},
|
||||||
|
"dependencies": {}
|
||||||
|
}
|
48
packages/switch/src/switch.pcss
Normal file
48
packages/switch/src/switch.pcss
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
|
||||||
|
@component-namespace o2{
|
||||||
|
@component switch {
|
||||||
|
height: 29px;
|
||||||
|
width: 49px;
|
||||||
|
display: inline-block;
|
||||||
|
border-radius: 16px;
|
||||||
|
position: relative;
|
||||||
|
border: 1px solid;
|
||||||
|
|
||||||
|
@descendent node {
|
||||||
|
width: 27px;
|
||||||
|
height: 27px;
|
||||||
|
border-radius: 100%;
|
||||||
|
background-color: #fff;
|
||||||
|
border: .5px solid rgba(0, 0, 0, .1);
|
||||||
|
position: absolute;
|
||||||
|
box-shadow: 0 3px 1px 0 rgba(0, 0, 0, .05), 0 2px 2px 0 rgba(0, 0, 0, .1), 0 3px 3px 0 rgba(0, 0, 0, .05);
|
||||||
|
@when on {
|
||||||
|
left: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
@when off {
|
||||||
|
right: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@when on {
|
||||||
|
background-color: #44db5e;
|
||||||
|
border-color: #44db5e;
|
||||||
|
}
|
||||||
|
|
||||||
|
@when off {
|
||||||
|
background-color: #fff;
|
||||||
|
border-color: rgba(0, 0, 0, .1);
|
||||||
|
}
|
||||||
|
|
||||||
|
@when loading {
|
||||||
|
/* TODO */
|
||||||
|
}
|
||||||
|
|
||||||
|
@when disabled {
|
||||||
|
background-color: #f2f2f2;
|
||||||
|
border-color: rgba(0, 0, 0, .1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
71
packages/switch/src/switch.vue
Normal file
71
packages/switch/src/switch.vue
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
<template>
|
||||||
|
<div class="o2-switch" :class="['is-' + switchState]" @click="toggleState">
|
||||||
|
<div class="o2-switch-node"></div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
/**
|
||||||
|
* o2-switch
|
||||||
|
* @module components/switch
|
||||||
|
* @desc 开关
|
||||||
|
* @param {boolean} [checked=false] - 开关状态
|
||||||
|
* @param {boolean} [disabled=false] - 禁用
|
||||||
|
* @param {boolean} [loading=false] - loading状态
|
||||||
|
* @param {callback} [onChange] - 开关状态改变回调函数。
|
||||||
|
*
|
||||||
|
* @example
|
||||||
|
* <o2-switch checked="true" disabled="false"></o2-switch>
|
||||||
|
*/
|
||||||
|
export default
|
||||||
|
{
|
||||||
|
name: 'o2-switch',
|
||||||
|
props: {
|
||||||
|
checked: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false
|
||||||
|
},
|
||||||
|
disabled: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false
|
||||||
|
},
|
||||||
|
loading: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false
|
||||||
|
},
|
||||||
|
onChange: {
|
||||||
|
type: Function,
|
||||||
|
default: function() {}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
switchState: function() {
|
||||||
|
if (this.disabled) {
|
||||||
|
return 'disabled';
|
||||||
|
} else if (this.loading) {
|
||||||
|
return 'loading';
|
||||||
|
} else if (this.checked) {
|
||||||
|
return 'on';
|
||||||
|
} else {
|
||||||
|
return 'off';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
/*
|
||||||
|
* 开关状态交互。
|
||||||
|
*/
|
||||||
|
toggleState: function() {
|
||||||
|
if(this.disabled || this.loading) return;
|
||||||
|
this.onChange(!this.checked);
|
||||||
|
},
|
||||||
|
|
||||||
|
/*
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
getState: function() {
|
||||||
|
return this.checked;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
</script>
|
@ -2,3 +2,4 @@
|
|||||||
css组件库 入口,从各个地方拿css文件,组装成css组件库
|
css组件库 入口,从各个地方拿css文件,组装成css组件库
|
||||||
*/
|
*/
|
||||||
@import '../../button/index.pcss';
|
@import '../../button/index.pcss';
|
||||||
|
@import '../../switch/index.pcss';
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
import Sample from '../packages/sample/index.js';
|
import Sample from '../packages/sample/index.js';
|
||||||
import Button from '../packages/button/index.js';
|
import Button from '../packages/button/index.js';
|
||||||
|
import Switch from '../packages/switch/index.js';
|
||||||
import 'es6-promise/auto';
|
import 'es6-promise/auto';
|
||||||
import axios from 'axios';
|
import axios from 'axios';
|
||||||
import foreach from 'lodash/foreach';
|
import foreach from 'lodash/foreach';
|
||||||
@ -14,6 +15,7 @@ const install = function(Vue) {
|
|||||||
|
|
||||||
Vue.component(Sample.name, Sample);
|
Vue.component(Sample.name, Sample);
|
||||||
Vue.component(Button.name, Button);
|
Vue.component(Button.name, Button);
|
||||||
|
Vue.component(Switch.name, Switch);
|
||||||
};
|
};
|
||||||
|
|
||||||
// auto install
|
// auto install
|
||||||
@ -32,5 +34,6 @@ module.exports = {
|
|||||||
map
|
map
|
||||||
},
|
},
|
||||||
Sample,
|
Sample,
|
||||||
Button
|
Button,
|
||||||
|
Switch
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user