-
Notifications
You must be signed in to change notification settings - Fork 21
/
Vue.js开发规范.md
254 lines (178 loc) · 7.26 KB
/
Vue.js开发规范.md
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
# <center> Vue.js 开发规范 </center>
## 一、命名
#### 1、文件夹
a) 开发的每个 **视图模块** 文件夹应创建在<kbd>/src/renderer/views/module</kbd>下,名称应和后端 **controllers 下级包名** 保持一致且为 **小驼峰命名** ,例如:
- 后端
```java
package com.cnetong.dxp.base.controllers.aces;
@RestController
@RequestMapping(value="/anon/aces")
public class LoginController extends BaseController {}
```
- 前端
```java
aces
```
#### 2、文件
a) 每个 **Vue 视图文件** 文件应创建在<kbd>/src/renderer/views/module/[模块]</kbd>下,名称应和后端 **Controllers** 名保持一致且为 **大驼峰命名** ,例如:
- 后端
```java
package com.cnetong.dxp.base.controllers.aces;
@RestController
@RequestMapping(value="/anon/aces")
public class LoginController extends BaseController {}
```
- 前端
```java
Login.vue
```
b) **JavaScript/Css** 文件使用 **小驼峰命名** 。
#### 3、变量
比较 **驼峰式命名** 和 **下划线命名** ,下划线命名虽然长但是会有明确的分割且因全是小写高度保持一致看起来比较舒服, 所以就是用下划线命名了!(就这理由能说服谁啊!)
> **下划线命名** 为 **全小写使用下划线进行单词的分割** ,由 **动词 _ 名词 _ 形容词 | 副词** 组成且单词长度不宜过长, 单词推荐简写至 4 位, 如果该变量不能表达出其意思, 那么就用注释补充吧!
a) **JavaScript/SCSS 变量** (作用域为整个.js 文件或更大的范围)使用 **下划线命名** 。
b) **Css 类** 使用 **中划线命名** ,组成结构和 **下划线命名** 一样。
#### 4、常量
a) **任何常量** 都使用 **下划线命名且字母全部大写**, 由 **动词 _ 名词 _ 形容词 | 副词** 组成且单词长度不宜过长, 单词推荐简写至 4 位, 如果该变量不能表达出其意思, 那么就用注释补充吧!
#### 5、方法
a) **任何方法** 都使用 **小驼峰命名** , 组成结构和 **下划线命名** 一样 ;
b) 由 **按钮触发** 的方法都以 **handle** 来代替 **动词** ;
c) 由 **业务触发** 的方法都以 **do** 来代替 **动词** ;
d) **事件绑定** 方法都以 **on** 来代替 **动词** ;
#### 6、其它
a) **路由名称** 使用 **小驼峰命名** 且和其组件文件名保持一致;
## 二、注释
**代码注释在一个项目的后期维护中显的尤为重要,所以我们要为每一个文件编写使用说明,为代码中每一个方法编写方法说明。**
#### 1、文件
a) 安装插件 **vscode-fileheader**,该插件可以记录 **创建人**、**创建时间**、**修改人**、**修改时间**,如果文件已经存在 fileheader 注释,那么它会在你修改文件时 **自动更新修改人和修改时间** 。
b) 配置插件
```json
"fileheader.Author": "Sun Rising",
"fileheader.LastModifiedBy": "Sun Rising"
```
c) 插件使用
组件新建时会自动生成文件注释或手动快捷键<kbd>ctrl+alt+i</kbd>,模板如下:
```javascript
/*
* @Author: Sun Rising
* @Date: 2018-12-08 10:51:48
* @Last Modified by: Sun Rising
* @Last Modified time: 2019-05-15 22:53:28
*/
```
#### 2、组件
a) 组件的作用、接收的参数,使用多行注释,模板如下:
```javascript
/**
* 编写理由:因使用tabs来实现路由分页显示并保存路由页面的状态...
* 适用场景:tabs路由分页
* 传入参数:{
* //缓存的key集合
* include: [Array],
* //排除的key集合
* exclude: [Array],
* //缓存的最大key数量
* max: [String, Number]
* }
* 备注:不用在 vue 页面写 name 属性了。。。!
*/
```
#### 3、变量
a) 这个变量是干嘛的,使用单行注释。
#### 4、方法
a) 这个方法是干嘛的,使用多行注释或单行,格式不限。
#### 5、核心语句
a) 如果你觉得语句复杂,那么就写点注释,说不定下次读这段代码的人就是你,在语句上方使用单行注释,
## 三、Element UI 使用
#### 1、组件
a) 组件元素书写时 **不要含有大写字母**,如下:
```javascript
//导入
import AisFooter from "@/components/core/AisFooter.vue";
//注册
components: {
AisFooter;
}
//使用
<ais-footer />;
```
#### 2、属性
a) 如果属性传入的是布尔值且传入为 true 时应 **简写** ,如下:
```html
<!-- 反例 -->
<el-menu :router="true" :default-active="$route.path" ...></el-menu>
<!--正例-->
<el-menu router :default-active="$route.path" ...></el-menu></el-menu>
```
b) el-table-column 标签要写 show-overflow-tooltip,如下:
```html
<el-table-column show-overflow-tooltip ... />
```
#### 3、事件
a) 如果调用的方法不需要参数传入,那么 **不要写小括号** 。
```html
<!-- 反例 -->
<el-button @click="handleAdd()"></el-button>
<!-- 正例 -->
<el-button @click="handleAdd"></el-button>
```
## 四、JavaScript 使用
#### 1、声明
a) vue 文件方法声明顺序,如下:
```css
- components //组件注册
- props //传入属性
- data //页面属性
- watch //数据监听
- computed //计算属性
- created //页面创建
- mounted //页面挂载
- activited //被keep-active加载
- update //页面更新
- beforeRouteUpdate //在当前路由改变,但是该组件被复用时调用
- metods //方法
```
b) 组件 props 原子化,提供 **默认值**,使用 type 属性 **校验类型**,使用 props 之前先检查该 prop 是否存在。
c) 使用 **ES6** 风格编码,定义变量使用 **let** ,定义常量使用 **const** 。
d) 避免 this.\$parent。
e) **调试信息 console.log() debugger 使用完及时删除** 。
#### 2、Ajax
a) 使用标准的 Ajax 书写方式,如下:
```javascript
//现在的写法
handleDelete() {
this.lock(); //进行遮罩
DecApi.delDec(this.decMessage.decHead.uuid)
.then(resp => {
//TODO ... //执行AJAX处理
this.unLock(); //无论如何要保证取消遮罩
})
.catch(e => {
//TODO ... //执行异常处理
this.unLock(); //无论如何要保证取消遮罩
});
},
//推荐的写法
async handleDelete() {
this.lock(); //进行遮罩
try {
let resp = await DecApi.delDec(this.decMessage.decHead.uuid);
//TODO ... //执行AJAX保存
} catch (e) {
if (e.hasInfo()) {
this.showMessage(e.info); //如果有消息,则提示消息
}
} finally {
this.unLock(); //无论如何要保证取消遮罩
}
}
```
## 五、CSS 使用
熟悉框架自带的 css 样式,例如 margin-top-4、pull-right 等等。
#### 1、全局
a) **新建项目专属的样式文件,不要写在框架的样式表中,防止框架升级时导致样式缺失的问题** ;
#### 2、局部
a) **在页面的最外层元素设置一个约束类,类选择器要添加这个约束或在style标签上使用scoped属性,防止影响上级的样式** ;
#### 3、组件
a) 样式的编写应该全部写在组件内部,防止迁移组件时样式会缺失;
b) 在页面的最外层元素设置一个约束类,类选择器要添加这个约束或在style标签上使用scoped属性,防止影响上级的样式;