vue3笔记(1)

人生兜兜转转几年没更新,转眼从产品变到项目管理又变成了前端。
最近使用Vue3+TS搭建了公司的服务平台,使用vue-cli5构建项目,UI使用了element-plus,记录一下代码写法和使用过程中的坑。

版本号对应

Vue CLI 4.5以下,对应的是Vue2。
Vue CLI 4.5及以上,对应的是Vue3,当然,创建项目的时候可以选择Vue2。

配置使用IP访问

package.json中添加启动配置

1
"serve": "vue-cli-service serve  --host 0.0.0.0"

效果展示

vue3搜索

基础写法

功能:通过表单内容搜索,列表展示搜索结果。

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
<template>
<el-main class="server-main">
<el-form
ref="serverUserFormRef"
:model="serverUserForm"
:rules="rules"
>
<el-form-item label="姓名" prop="alias_name">
<el-input
v-model="serverUserForm.alias_name"
name="alias_name"
type="text"
placeholder="请输入用户名"
>
</el-input>
<el-button
type="primary"
icon="Edit"
@click.prevent="handleAdd(serverUserFormRef)"
>创建
</el-button>
</el-form>
<el-table :data="tableData">
<template v-for="(item, index) in columns" :key="index">
<el-table-column
v-bind="item"
show-overflow-tooltip>
</el-table-column>
</template>
</el-table>
</el-main>
</template>
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
<script lang="ts">
import { defineComponent, ref, reactive, toRefs, onMounted } from 'vue';
import { getUsers, createUser} from "@/api/users";
import { ElMessage, ElMessageBox, ElNotification } from "element-plus";
import { Search } from '@element-plus/icons-vue';
import FormInstance from "element-plus";

export default defineComponent({
name: "XX",
components: {},
setup() {
const emyptForm = {
alias_name: "",
}
const state = reactive({
serverUserForm: JSON.parse(JSON.stringify(emyptForm)),
tableData:[]
});
const columns = [
{ label: "用户", prop: "alias_name", width: "200" },
];

onMounted(() => {
getData();
});

const getData = () => {
getUsers({}).then(res => {
const { data } = res.data
state.tableData = data.results;
}).catch((error) => {
ElMessage.error('获取数据错误!');
})
}
const serverUserFormRef = ref<typeof FormInstance>();
const rules = {
alias_name: [{ required: true, message: "请输入用户名", trigger: "blur" }]
};

const clearAll = () => {
state.serverUserForm = JSON.parse(JSON.stringify(emyptForm));
}
// 新增
const handleAdd = (formEl) => {
formEl.validate((valid: boolean) => {
if (valid) {
const params = state.serverUserForm;
createUser(params).then(res => {
const { code, data } = res.data
if(code == 0) {
ElNotification({
title: '操作成功',
message: h('i', { style: 'color: teal' }, '用户已新增!'),
});
getData();
} else {
ElMessage.error('新增用户错误,请重试!');
}
}).catch(error => {
ElMessage.error('服务器修复中,请稍后重试!');
});
clearAll();
} else {
return false;
}
})
}
return {
serverUserFormRef,
...toRefs(state),
rules,
handleAdd,
columns,
};
}
});
</script>

typescript忽略类型检查

单行忽略(添加到特定行的行前来忽略这一行的错误)
// @ts-ignore

跳过对某些文件的检查 (添加到该文件的首行才起作用)
// @ts-nocheck

对某些文件的检查
// @ts-check


vue3笔记(1)
https://guoningyan.com/2022/04/26/vue3笔记(1)/
作者
Ningyan Guo
发布于
2022年4月26日
许可协议