在参与 Vant 开发时,请遵守约定的单文件组件风格指南,指南内容节选自 Vue 官方风格指南。
组件的 data 必须是一个函数。
// bad
export default {
data: {
foo: "bar",
},
};
// good
export default {
data() {
return {
foo: "bar",
};
},
};
单文件组件的文件名应该要么始终是单词大写开头 (PascalCase),要么始终是横线连接 (kebab-case)。
// bad
mycomponent.vue
myComponent.vue
// good
my-component.vue
MyComponent.vue
和父组件紧密耦合的子组件应该以父组件名作为前缀命名。
// bad
components/
|- TodoList.vue
|- TodoItem.vue
└─ TodoButton.vue
// good
components/
|- TodoList.vue
|- TodoListItem.vue
└─ TodoListItemButton.vue
在单文件组件中没有内容的组件应该是自闭合的。
<!-- bad -->
<my-component></my-component>
<!-- good -->
<my-component />
在声明 prop 的时候,其命名应该始终使用 camelCase,而在模板中应该始终使用 kebab-case。
// bad
export default {
props: {
"greeting-text": String,
},
};
// good
export default {
props: {
greetingText: String,
},
};
<!-- bad -->
<welcome-message greetingText="hi" />
<!-- good -->
<welcome-message greeting-text="hi" />
指令缩写,用 :
表示 v-bind:
,用 @
表示 v-on:
<!-- bad -->
<input v-bind:value="value" v-on:input="onInput" />
<!-- good -->
<input :value="value" @input="onInput" />
标签的 Props 应该有统一的顺序,依次为指令、属性和事件。
<my-component
v-if="if"
v-show="show"
v-model="value"
ref="ref"
:key="key"
:text="text"
@input="onInput"
@change="onChange"
/>
组件选项应该有统一的顺序。
export default {
name: "",
components: {},
props: {},
emits: [],
setup() {},
data() {},
computed: {},
watch: {},
created() {},
mounted() {},
unmounted() {},
methods: {},
};
组件选项较多时,建议在属性之间添加空行。
export default {
computed: {
formattedValue() {
// ...
},
styles() {
// ...
},
},
methods: {
onInput() {
// ...
},
onChange() {
// ...
},
},
};
单文件组件应该总是让顶级标签的顺序保持一致,且标签之间留有空行。
<template> ... </template>
<script>
</script>
<style>
</style>
介绍用户可以在文本框内输入或编辑文字。引入通过以下方式来全局注册组件,更多注册方式请参考组件注册。import { createApp } f...
介绍圆环形的进度条组件,支持进度渐变动画。引入通过以下方式来全局注册组件,更多注册方式请参考组件注册。import { createApp...
介绍级联选择框,用于多层级数据的选择,典型场景为省市区选择。实例演示引入通过以下方式来全局注册组件,更多注册方式请参考组...
介绍底部导航栏,用于在不同页面之间进行切换。实例演示引入通过以下方式来全局注册组件,更多注册方式请参考组件注册。import {...
提供了一套常用的图标集合。使用方法直接通过设置类名为 el-icon-iconName 来使用即可。例如:render() {return (divi className...
内置过渡动画Element Plus 内应用在部分组件的过渡动画,你也可以直接使用。在使用之前请阅读transition 组件文档。fade 淡入淡...