Vue3、ElementPlus速通

2024-09-01 20:52

本文主要是介绍Vue3、ElementPlus速通,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Vue基础

Vue介绍

原生的JS在程序开发的过程中书写起来是十分麻烦的,因此很多的前端的框架(半成品)就应运而生了,目前比较知名的是下面三个

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

Vue是一个用于构建用户界面的渐进式框架,目前企业中流行的版本有两个

image-20240524183823123

入门案例

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>快速入门</title>
</head><body><!--3. 使用vue声明一个变量username, 并把它的值显示在div中--><div id="app">{{username}}</div><script type="module">// 1. 导入vue的js文件import { createApp, ref } from 'https://unpkg.com/vue@3/dist/vue.esm-browser.js'//2. 创建vue对象createApp({//数据data() {return {username: "张三"}}}).mount('#app')</script></body></html>

插值表达式是一种Vue的模板语法,用于给页面进行赋值,注意点:

  1. {{}}除了基本的赋值外,还可以进行简单的方法调用、数学运算、三元运算等等
  2. {{}}中仅仅支持表达式,不支持语句,比如:if、for
  3. {{}}中使用的数据必须在data中存在
  4. {{}}不能为标签的属性进行赋值

Vue指令

Vue的指令就类似于Java的关键字,是Vue内置好一些有特点含义的语法标签,一般格式都是v-xxxx

页面赋值(v-html)

v-html用于将指定变量的值渲染到页面上,如果变量值中有html语法,会进行解析

此标签跟插值表达式功能相似,区别在于插值表达式不会进行html语法的解析

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>快速入门</title>
</head><body><!-- v-html用于将指定变量的值渲染到页面上,如果变量值中有html语法,会进行解析此标签跟插值表达式功能相似,区别在于插值表达式不会进行html语法的解析--><div id="app">使用插值表达式的效果: {{str}} <br>使用插值v-html的效果: <span v-html="str">好孩子</span></div><script type="module">/* 1. 导入vueJS的主入口类 */import {createApp} from 'https://unpkg.com/vue@3/dist/vue.esm-browser.js';//import {createApp} from './js/vue.esm-browser.js';/* 2. 创建Vue对象 */createApp({data(){return {str:"我是一个<b>好学生</b>"}}}).mount('#app');</script>
</body></html>

双向绑定(v-model)

v-model是双向绑定,视图(View)和模型(Model)之间会互相影响

目前v-model的可使用元素有:input、select、textarea

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>双向绑定</title>
</head><body><!-- v-model是双向绑定,视图(View)和模型(Model)之间会互相影响目前v-model的可使用元素有:input、select、textarea--><div id="app"><h3>姓名:</h3><input type="text" v-model="username"><div>您写的姓名是:{{username}}</div><h3>性别:</h3><input type="radio" value="" v-model="gender"><br><input type="radio" value="" v-model="gender"><br><div>您选择的性别是:{{gender}}</div><h3>爱好:</h3><input type="checkbox" value="抽烟" v-model="hobby">抽烟<br><input type="checkbox" value="喝酒" v-model="hobby">喝酒<br><input type="checkbox" value="烫头" v-model="hobby">烫头<br><div>您选择的爱好是:{{hobby}}</div><h3>段位:</h3><select v-model="level"><option value="">请选择</option><option value="青铜">青铜</option><option value="白银">白银</option><option value="王者">王者</option></select><div>您选择的段位是:{{level}}</div></div><script type="module">import { createApp } from 'https://unpkg.com/vue@3/dist/vue.esm-browser.js';createApp({data() {return {"username": "张三","gender": "男","hobby": ["喝酒"],"level": "青铜"}}}).mount('#app');</script>
</body></html>

属性绑定(v-bind)

对于HTML标签属性,如果想要动态传值,不能使用{{}},而应该使用专门的属性绑定语法

标准语法:v-bind:属性名=“Vue中的变量”

简写语法: :属性名=“Vue中的变量”

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>属性绑定</title>
</head><body><!-- 对于HTML标签属性,如果想要动态传值,不能使用{{}},而应该使用专门的属性绑定语法标准语法:v-bind:属性名="Vue中的变量"简写语法:      :属性名="Vue中的变量"--><div id="app"><h3>属性绑定基本使用</h3>有两个图片地址分别是:./img/vue.png 和 ./img/mn.jpg,请在下面输入地址,改变图片:<br>图片地址: <input type="text" v-model="imgSrc">图片宽度: <input type="text" v-model="imgWidth"><br><img v-bind:src="imgSrc" :width="imgWidth"></div><script type="module">import {createApp} from 'https://unpkg.com/vue@3/dist/vue.esm-browser.js';createApp({data(){return {imgSrc: "./img/vue.png",imgWidth: "100px"}}}).mount('#app');</script>
</body></html>

列表遍历(v-for)

v-for=“(临时变量,索引) in 数组”

遍历哪个标签,就要将这个指令当成属性写在谁哪个标签上

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>列表遍历</title>
</head><body><!-- v-for="(临时变量,索引) in 数组"注意:遍历哪个标签,就要将这个指令当成属性写在谁哪个标签上--><div id="app"><table border="1" cellspacing="0" cellpadding="0" width="500px"><tr><th>id</th><th>name</th><th>address</th></tr><tr v-for="(user,item) in users" :key="user.id"><td>{{user.id}}</td><td>{{user.name}}</td><td>{{user.address}}</td></tr></table></div><script type="module">import { createApp } from 'https://unpkg.com/vue@3/dist/vue.esm-browser.js';createApp({data() {return {users: [{ id: 1, name: 'jack', address: '北京顺义' },{ id: 2, name: 'lucy', address: '上海虹桥' },{ id: 3, name: 'jerry', address: '天津宝坻' }]}}}).mount('#app');</script>
</body></html>

条件判断(v-if/v-show)

语法:

​ v-if=布尔值 条件性的创建或者移除某些元素,判定为true时创建,判定为false移除

​ v-show=布尔值 条件性的显示或者隐藏某些元素,判定为true时显示,判定为false隐藏

注意:

​ 1) v-if 一般用于要么显示,要么隐藏的场景;v-show用于频繁切换显示和隐藏的场景

​ 2) v-if还可以配合v-else以及v-else-if实现多分支条件判断,此时要注意三个标签中间不能有其它内容

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>条件判断</title>
</head><body><!-- 语法:    v-if 条件性的创建或者移除某些元素,判定为true时创建,判定为false移除v-show 条件性的显示或者隐藏某些元素,判定为true时显示,判定为false隐藏注意:    1) v-if 一般用于要么显示,要么隐藏的场景;v-show用于频繁切换显示和隐藏的场景2) v-if还可以配合v-else以及v-else-if实现多分支条件判断,此时要注意三个标签中间不能有其它内容--><div id="app"><!--从文本框输入成绩, 然后判断成绩是否及格  >=60:及格    <60:不及格-->请输入成绩:<input type="text" v-model="score"><br><h3>v-if判断考试结果</h3>您本次开始成绩:<span v-if="score >= 60">及格</span><span v-else-if="score < 60">不及格</span><span v-else>成绩无效</span><!--         <span v-if="score >= 60">及格</span><span v-if="score < 60">不及格</span> --><h3>v-show判断考试结果</h3>您本次开始成绩:<span v-show="score >= 60">及格</span><span v-show="score < 60">不及格</span></div><script type="module">import { createApp } from 'https://unpkg.com/vue@3/dist/vue.esm-browser.js';createApp({data() {return {score: "0",}}}).mount('#app');</script>
</body></html>

事件绑定(v-on)

事件绑定用于给页面元素添加事件,js支持的事件vue都支持

标准语法 v-on:事件名=“函数名”

简化语法 @事件名=“函数名”

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>事件绑定</title>
</head><body><!-- 事件绑定用于给页面元素添加事件,js支持的事件vue都支持标准语法   v-on:事件名="函数名"简化语法   @事件名="函数名"--><div id="app"><b>数量:</b><button @click="diff()">-</button><input type="text" v-model="num" style="width: 30px;"><button v-on:click="add()">+</button></div><script type="module">import { createApp } from 'https://unpkg.com/vue@3/dist/vue.esm-browser.js';createApp({data() {return {num: 1}},methods: {add() {this.num++},diff() {this.num--}}}).mount('#app');</script>
</body></html>

axios

axios是一个可以从前端向后端发送ajax请求的小框架,为Vue官方所推荐

//axios 发送get请求	
axios.get("url?username=zhangsan&password=123").then(resp=>{resp.data;//返回结果
})// axios发送post请求
axios.post("url",{"username":"zhangsan","password":"123"}).then(resp=>{resp.data;//返回结果
})
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><title>vue表格制作</title><!--使用Axios向指定后台发送请求,将拉取的数据使用vue技术渲染成HTML表格后台的数据地址是:https://mock.apifox.cn/m1/3128855-0-default/emp/list-->
</head><body><div id="app"><table border="1" cellspacing="0" width="60%"><tr id="head"><th>编号</th><th>姓名</th><th>图像</th><th>性别</th><th>职位</th><th>入职日期</th><th>最后操作时间</th></tr><tr v-for="(emp,index) in empList" :key="emp.id"><td>{{emp.id}}</td><td>{{emp.name}}</td><td><img :src="emp.image" width="50px"> </td><td>{{emp.gender == 1 ? "男" : "女"}}</td><td>{{emp.job}}</td><td>{{emp.entrydate}}</td><td>{{emp.updateTime}}</td></tr></table></div><script src="./js/axios.js"></script><script type="module">import { createApp } from 'https://unpkg.com/vue@3/dist/vue.esm-browser.js';createApp({data() {return {empList: []}},methods: {findList() {axios.get("https://mock.apifox.cn/m1/3128855-0-default/emp/list").then(resp => {this.empList = resp.data.data;})}},created() { // 页面加载完毕后调用findList方法this.findList();}}).mount('#app');</script>
</body></html>

前端工程化

前端工程化就是在企业级的前端项目开发中,把前端开发所需要的工具、技术、流程、经验进行规范化和标准化

安装NodeJS

在开发项目之前,我们需要安装下NodeJS,它是前端开发的基础环境,相当于Java的JDK

① 双击资料中提供的安装包,启动安装程序

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

② 选择安装到一个没有中文没有空格的目录下,新建一个文件夹nodejs

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

③ 安装完毕后,通过node -v验证一下是否安装成功

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

④ 使用管理员身份运行命令行,执行如下指令配置npm的全局安装路径

npm config set prefix "D:\soft\nodejs"

注意:D:\soft\nodejs\这个目录是NodeJS的安装目录

⑤ 使用管理员身份运行命令行,执行如下指令切换镜像源

npm config set strict-ssl false
npm config set registry https://registry.npm.taobao.org

创建项目

接下来使用npm init vue@latest安装一个vue3的项目,这个过程中它会自动安装脚手架并初始化工程

安装的过程中会提示一些选项如下:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

为了接下来的开发,我们还需要安装几个vscode的插件:

  • Vue-Official 语法高亮,智能提示,emmet,错误提示,格式化,自动补全
  • Vue VSCode Snippets: 快捷键
  • Vetur
  • VueHelper

启动项目

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

项目介绍

打开项目会发现很多目录,下面了解下每个目录的作用

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

我们以main.js作为文件的主入口,此文件会引入我们开发的根组件App.vue

我们可以在根组件中编写代码,也可以在其它自定义组件中开发,再引入到根组件中

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

组件:我们开发代码的主战场,一般包含三部分:script(定义js)、template(定义HTML)、style(定义css)

修改App.Vue,自定义首页

<!-- 注意: 先删掉script标签的setup属性 -->
<script>
export default {data() {return {message: "Hello"}}
}
</script><template><div><span class="msg">{{ message }}</span></div>
</template><style scoped>
.msg {color: red;
}
</style>

API风格

在Vue中,有两种不同的风格:选项式API和组合式API

选项式API

选项式API允许导出多个对象(data、methods、mounted)来描述数据、方法、钩子函数

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

<!-- 注意: 先删掉script标签的setup属性 -->
<script>
export default {//数据data() {return {count: 1}},//方法methods:{increment(){this.count++;},decrement(){this.count--;}}
}
</script><template><div><button @click="decrement()">-</button><span class="msg">{{ count }}</span><button @click="increment()">+</button></div>
</template><style scoped>
.msg {color: red;display: inline-block;width: 20px;text-align: center;
}
</style>

组合式API

组合式API用起来更加的简便

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

<!-- 1. 在script标签上添加setup属性2. 变量直接使用ref声明3. 方法直接定义4. 构造函数 直接写
-->
<script setup>
import { onMounted, ref } from 'vue';//变量(这样声明出来的count是个对象 使用.value属性可以访问它的值)
const count = ref(1);//方法
const increment = function () {count.value++;
}
const decrement = () => {count.value--;
}//钩子函数
onMounted(() => {count.value = 10;
})</script><template><div><button @click="decrement()">-</button><span class="msg">{{ count }}</span><button @click="increment()">+</button></div>
</template><style scoped>
.msg {color: red;display: inline-block;width: 20px;text-align: center;
}
</style>

组件化

组件就是将一个页面可以拆分成一个个小部分,每个小部分有着自己独立的结构、样式、行为,这一个小部分就称为组件,组件便于维护,利于复用 。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

组件分为两类:根组件和普通组件,根组件就一个–App.vue,它用来装载普通组件,普通组件可以有很多个,普通组件也可以装载其它普通组件

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

局部注册组件

局部注册:只能在注册的组件内使用

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

① 创建header组件

<script setup></script><template><div class="header">我是hm-header</div>
</template><style scoped>.header{width: 500px;height: 100px;background-color: blueviolet;text-align: center;font-size: 20px;color: aliceblue;}
</style>

② 创建main组件

<script setup></script><template><div class="header">我是hm-main</div>
</template><style scoped>.header{width: 500px;height: 400px;background-color:orange;text-align: center;font-size: 20px;color: aliceblue;}
</style>

③ 创建footer组件

<script setup></script><template><div class="footer">我是hm-footer</div>
</template><style scoped>.footer{width: 500px;height: 100px;background-color:cornflowerblue;text-align: center;font-size: 20px;color: aliceblue;}
</style>

④ 在根组件中导入上面的三个组件并注册使用

<script setup>
//1. 将组件文件导入进来
import HmHeader from './components/HmHeader.vue'
import HmMain from './components/HmMain.vue'
import HmFooter from './components/HmFooter.vue'components: {/* 标签:组件变量名 */HmHeader,HmMain,HmFooter
}
</script><template><div><!-- 3. 将组件等价标签写在html中 --><hm-header></hm-header><hm-main></hm-main><hm-footer></hm-footer></div>
</template><style scoped></style>

全局注册组件

全局注册:在所有组件中都能使用

全局注册跟局部注册的开发步骤很相近,不一样的地方在于注册的时候需要在main.js中注册,这样就可以在任意一个其它组件中使用了

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

① 创建button组件

<script setup></script><template><div><button>按钮</button></div>
</template><style scoped>button{width: 100px;height: 40px;background-color: darkturquoise;color: white;}
</style>

② 注册全局组件

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

③ 在任何需要使用组件的时候直接使用标签名调用

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

ElementPlus

Element是饿了么公司前端开发团队提供的一套基于Vue的网站组件库,作用是帮助开发人员快速搭建网站

Element提供了大量的写好的页面组件,例如按钮、图片、表格、导航条、表单等等,开发人员可以直接复制使用

参考网站:https://element-plus.org/zh-CN/

我们自己编写的按钮

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

Element提供的按钮

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

快速入门

  1. 使用npm install element-plus --save命令安装element-plus的包

  2. 在main.js中导入并创建ElementPlus的实例

    import { createApp } from 'vue'
    import ElementPlus from 'element-plus'
    import 'element-plus/dist/index.css'
    import App from './App.vue'const app = createApp(App)app.use(ElementPlus)
    app.mount('#app')
    
  3. 从ElementPlus官方复制代码到App.vue中,查看效果

    https://element-plus.org/zh-CN/component/button.html

    <script lang="ts" setup>
    </script><template><div class="mb-4"><el-button>Default</el-button><el-button type="primary">Primary</el-button><el-button type="success">Success</el-button><el-button type="info">Info</el-button><el-button type="warning">Warning</el-button><el-button type="danger">Danger</el-button></div>
    </template>
    

容器布局

Element的容器布局将页面分成头部区域、侧边栏区域、主区域、底部区域。

https://element-plus.org/zh-CN/component/container.html

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

<template><div class="common-layout"><el-container><!-- 头部组件 --><el-header>Header</el-header><el-container><!-- 左侧边栏 --><el-aside width="200px">Aside</el-aside><!-- 主内容区域 --><el-main>Main</el-main></el-container></el-container></div>
</template>

水平导航栏

https://element-plus.org/zh-CN/component/menu.html

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

<template><!-- el-menu: 导航栏default-active="activeIndex" 默认选中项(值是最终节点索引)mode="vertical(垂直)|horizontal(水平)" @select="handleSelect"  选择其中一项时时间el-menu-item 没有下一层index 索引el-sub-menu 有下一层--><el-menu :default-active="activeIndex" class="el-menu-demo" mode="horizontal" :ellipsis="false"@select="handleSelect"><el-menu-item index="0">xxxx</el-menu-item><el-menu-item index="1">Processing Center</el-menu-item><el-sub-menu index="2"><template #title>Workspace</template><el-menu-item index="2-1">item one</el-menu-item><el-menu-item index="2-2">item two</el-menu-item><el-menu-item index="2-3">item three</el-menu-item><el-sub-menu index="2-4"><template #title>item four</template><el-menu-item index="2-4-1">item one</el-menu-item><el-menu-item index="2-4-2">item two</el-menu-item><el-menu-item index="2-4-3">item three</el-menu-item></el-sub-menu></el-sub-menu></el-menu>
</template><script lang="ts" setup>
import { ref } from 'vue'const activeIndex = ref('2-4-2')//key 选中项目的索引
const handleSelect = (key: string, keyPath: string[]) => {console.log(key, keyPath)
}
</script><style>
.el-menu--horizontal>.el-menu-item:nth-child(1) {margin-right: auto;
}
</style>

垂直导航栏

垂直菜单,可内嵌子菜单。

https://element-plus.org/zh-CN/component/menu.html

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

<template><el-row class="tac"><!--el-menu: 主导航class="css样式"mode="horizontal|vertical"  导航模式background-color="背景色"text-color="文字颜色"active-text-color="激活文字颜色"default-active="3" 激活哪一项 , 激活必须定位到最末级@select="选择事件"el-menu-item: 子导航(无下级)index="2"  索引el-submenu: 子导航(有下级)@open="handleOpen" @close="handleClose"  开关事件--><el-menu active-text-color="#ffd04b" background-color="#545c64" class="el-menu-vertical-demo" default-active="2"text-color="#fff" @open="handleOpen" @close="handleClose"><el-sub-menu index="1"><template #title><el-icon><location /></el-icon><span>Navigator One</span></template><el-menu-item-group title="Group One"><el-menu-item index="1-1">item one</el-menu-item><el-menu-item index="1-2">item two</el-menu-item></el-menu-item-group><el-menu-item-group title="Group Two"><el-menu-item index="1-3">item three</el-menu-item></el-menu-item-group><el-sub-menu index="1-4"><template #title>item four</template><el-menu-item index="1-4-1">item one</el-menu-item></el-sub-menu></el-sub-menu><el-menu-item index="2"><el-icon><icon-menu /></el-icon><span>Navigator Two</span></el-menu-item><el-menu-item index="3" disabled><el-icon><document /></el-icon><span>Navigator Three</span></el-menu-item><el-menu-item index="4"><el-icon><setting /></el-icon><span>Navigator Four</span></el-menu-item></el-menu></el-row>
</template><script lang="ts" setup>
import {Document,Menu as IconMenu,Location,Setting,
} from '@element-plus/icons-vue'
const handleOpen = (key: string, keyPath: string[]) => {console.log(key, keyPath)
}
const handleClose = (key: string, keyPath: string[]) => {console.log(key, keyPath)
}
</script>

表格组件

表格组件用于展示多条结构类似的数据,可对数据进行编辑、删除或其他自定义操作

https://element-plus.org/zh-CN/component/table.html

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

<template><!-- el-table 表格data: 表格数据el-table-column  列prop="从data提供数组的对象中取哪个属性值" label="表头文字"	--><el-table :data="tableData" border style="width: 100%"><el-table-column prop="date" label="日期" width="180" /><el-table-column prop="name" label="Name" width="180" /><el-table-column prop="address" label="Address" /></el-table>
</template><script lang="ts" setup>
const tableData = [{date: '2016-05-03',name: 'Tom',address: 'No. 189, Grove St, Los Angeles',},{date: '2016-05-02',name: 'Tom',address: 'No. 189, Grove St, Los Angeles',},{date: '2016-05-04',name: 'Tom',address: 'No. 189, Grove St, Los Angeles',},{date: '2016-05-01',name: 'Tom',address: 'No. 189, Grove St, Los Angeles',},
]
</script>

分页组件

当数据量过多时,使用分页分解数据。

https://element-plus.org/zh-CN/component/pagination.html

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

<template><!-- layout 控制显示哪些内容disabled 是否禁用background 是否加背景total 总记录数page-size 每页大小current-page 当期页码:size="size"  总页数:page-sizes="[100, 200, 300, 400]" 前端用的每页大小选择框@size-change="handleSizeChange"   每页大小改变时触发事件@current-change="handleCurrentChange"  页码改变时触发事件--><el-pagination layout="total, sizes, prev, pager, next, jumper":disabled="disabled" :background="background" :total="400":page-sizes="[100, 200, 300, 400]":size="size" v-model:current-page="currentPage4" v-model:page-size="pageSize4" @size-change="handleSizeChange" @current-change="handleCurrentChange"/>
</template>
<script lang="ts" setup>
import { ref } from 'vue'
import type { ComponentSize } from 'element-plus'
const currentPage1 = ref(5)
const currentPage2 = ref(5)
const currentPage3 = ref(5)
const currentPage4 = ref(4)
const pageSize2 = ref(100)
const pageSize3 = ref(100)
const pageSize4 = ref(100)
const size = ref<ComponentSize>('default')
const background = ref(false)
const disabled = ref(false)const handleSizeChange = (val: number) => {console.log(`${val} items per page`)
}
const handleCurrentChange = (val: number) => {console.log(`current page: ${val}`)
}
</script><style scoped>
.demo-pagination-block+.demo-pagination-block {margin-top: 10px;
}.demo-pagination-block .demonstration {margin-bottom: 16px;
}
</style>

设置中文: https://blog.csdn.net/m0_56164131/article/details/140198734

对话框

在保留当前页面状态的情况下,弹出一个子窗口,完成操作

https://element-plus.org/zh-CN/component/dialog.html

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

<template><!-- 按钮 --><el-button plain @click="dialogFormVisible = true">Open a Form nested Dialog</el-button><!-- dialogFormVisible : 控制对话框是否显示--><!-- 对话框 --><el-dialog v-model="dialogFormVisible" title="Shipping address" width="500"><!-- 表单 --><el-form :model="form"><el-form-item label="Promotion name" :label-width="formLabelWidth"><el-input v-model="form.name" autocomplete="off" /></el-form-item><el-form-item label="Zones" :label-width="formLabelWidth"><el-select v-model="form.region" placeholder="Please select a zone"><el-option label="Zone No.1" value="shanghai" /><el-option label="Zone No.2" value="beijing" /></el-select></el-form-item></el-form><!-- 小按钮 --><template #footer><div class="dialog-footer"><el-button @click="dialogFormVisible = false">Cancel</el-button><el-button type="primary" @click="dialogFormVisible = false">Confirm</el-button></div></template></el-dialog>
</template><script lang="ts" setup>
import { reactive, ref } from 'vue'const dialogTableVisible = ref(false)
const dialogFormVisible = ref(false)  //控制对话框是否显示
const formLabelWidth = '140px'const form = reactive({name: '',region: '',date1: '',date2: '',delivery: false,type: [],resource: '',desc: '',
})</script>

表单组件

表单组件由输入框、下拉列表、单选框、多选框等控件组成,用以收集、校验、提交数据。

https://element-plus.org/zh-CN/component/form.html

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

<template><el-form :model="form" label-width="auto" style="max-width: 600px"><el-form-item label="Activity name"><el-input v-model="form.name" /></el-form-item><el-form-item label="Activity zone"><el-select v-model="form.region" placeholder="please select your zone"><el-option label="Zone one" value="shanghai" /><el-option label="Zone two" value="beijing" /></el-select></el-form-item><el-form-item label="Activity time"><el-col :span="11"><el-date-picker v-model="form.date1" type="date" placeholder="Pick a date" style="width: 100%" /></el-col><el-col :span="2" class="text-center"><span class="text-gray-500">-</span></el-col><el-col :span="11"><el-time-picker v-model="form.date2" placeholder="Pick a time" style="width: 100%" /></el-col></el-form-item><el-form-item label="Instant delivery"><el-switch v-model="form.delivery" /></el-form-item><el-form-item label="Activity type"><el-checkbox-group v-model="form.type"><el-checkbox value="Online activities" name="type">Online activities</el-checkbox><el-checkbox value="Promotion activities" name="type">Promotion activities</el-checkbox><el-checkbox value="Offline activities" name="type">Offline activities</el-checkbox><el-checkbox value="Simple brand exposure" name="type">Simple brand exposure</el-checkbox></el-checkbox-group></el-form-item><el-form-item label="Resources"><el-radio-group v-model="form.resource"><el-radio value="Sponsor">Sponsor</el-radio><el-radio value="Venue">Venue</el-radio></el-radio-group></el-form-item><el-form-item label="Activity form"><el-input v-model="form.desc" type="textarea" /></el-form-item><el-form-item><el-button type="primary" @click="onSubmit">Create</el-button><el-button>Cancel</el-button></el-form-item></el-form>
</template><script lang="ts" setup>
import { reactive } from 'vue'// do not use same name with ref
const form = reactive({name: '',region: '',date1: '',date2: '',delivery: false,type: [],resource: '',desc: '',
})const onSubmit = () => {console.log('submit!')
}
</script>

综合案例

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传 ,

<script lang="ts" setup>
import { onMounted, ref } from 'vue'
import {Aim,Document,Menu as IconMenu,Location,Setting,Timer
} from '@element-plus/icons-vue'
import axios from 'axios'
import { ElMessage, ElMessageBox } from 'element-plus'
import type { ComponentSize } from 'element-plus'//查询学生列表
const pageNum = ref(1) //当前页
const pageSize = ref(5) //每页条数
const total = ref(0) //总记录数
const size = ref<ComponentSize>('default')
const handleSizeChange = (val: number) => {findList();
}
const handleCurrentChange = (val: number) => {findList();
}
const studentList = ref([])
const findList = function () {//发送请求// axios.get("http://localhost:8090/student").then(resp => {// 	studentList.value = resp.data.data;// })axios.get("http://localhost:8090/student/findByPage", {params: {pageNum: pageNum.value,pageSize: pageSize.value}}).then(resp => {total.value = resp.data.data.total;studentList.value = resp.data.data.rows;})
}//新增学生
const studentAddFrom = ref({}) //封装添加框数据
const addFormVisible = ref(false) //控制添加框显示
const addStudent = function () {//发送请求axios.post('http://localhost:8090/student', studentAddFrom.value).then(resp => {if (resp.data.code == 1) {//1. 关闭窗口addFormVisible.value = false//2. 清空添加框studentAddFrom.value = {}//3. 重新查询findList();}})
}//修改学生
const studentUpdateFrom = ref({}) //封装添加框数据
const updateFormVisible = ref(false) //控制添加框显示
//点击修改框
const handleEdit = (index, row) => {//打开修改框updateFormVisible.value = true//根据id查询axios.get("http://localhost:8090/student/" + row.id).then(resp => {studentUpdateFrom.value = resp.data.data})//console.log(index, row.id)
}
//点击修改框修改按钮
const updateStudent = function () {//发送请求axios.put('http://localhost:8090/student', studentUpdateFrom.value).then(resp => {if (resp.data.code == 1) {//1. 关闭窗口updateFormVisible.value = false//2. 清空添加框studentUpdateFrom.value = {}//3. 重新查询findList();}})
}//删除
const handleDelete = (index, row) => {ElMessageBox.confirm('您是否确认要删除本条记录?','',{confirmButtonText: '确认',cancelButtonText: '取消',type: 'warning',}).then(() => {axios.delete("http://localhost:8090/student/" + row.id).then(resp => {if (resp.data.code == 1) {findList();ElMessage({type: 'success',message: '删除成功',})}})})
}//页面加载完毕
onMounted(function () {findList();
})</script><template><!-- 主界面 --><div class="common-layout"><el-container><el-header><el-menu class="el-menu-demo" mode="horizontal" background-color="#545c64" text-color="#fff"active-text-color="#ffd04b" :ellipsis="false"><el-menu-item index="1" style="margin-right: auto;">Export</el-menu-item><el-menu-item index="3">处理中心</el-menu-item><el-sub-menu index="2"><template #title>我的工作台</template><el-menu-item index="2-1">item one</el-menu-item><el-menu-item index="2-2">item two</el-menu-item><el-menu-item index="2-3">item three</el-menu-item></el-sub-menu><el-menu-item index="4">首页</el-menu-item></el-menu></el-header><el-container><el-aside width="200px"><el-menu default-active="1-1" class="el-menu-vertical-demo"><el-sub-menu index="1"><template #title><el-icon><location /></el-icon><span>学工部</span></template><el-menu-item index="1-1"><el-icon><Aim /></el-icon>在校学生管理</el-menu-item><el-menu-item index="1-2"><el-icon><Aim /></el-icon>学生升级/留级</el-menu-item><el-menu-item index="1-3"><el-icon><Aim /></el-icon>学生就业情况</el-menu-item></el-sub-menu><el-sub-menu index="2"><template #title><el-icon><Setting /></el-icon><span>咨询部</span></template><el-menu-item index="2-1">在校学生管理</el-menu-item><el-menu-item index="2-2">学生升级/留级</el-menu-item><el-menu-item index="2-3">学生就业情况</el-menu-item></el-sub-menu><el-sub-menu index="3"><template #title><el-icon><Document /></el-icon><span>教研部</span></template><el-menu-item index="3-1">在校学生管理</el-menu-item><el-menu-item index="3-2">学生升级/留级</el-menu-item><el-menu-item index="3-3">学生就业情况</el-menu-item></el-sub-menu></el-menu></el-aside><el-main><div><span style="font-weight: bold;color: red;">学生列表</span><el-button type="primary" style="float: right;" @click="addFormVisible = true">添加学生</el-button></div><div><el-table :data="studentList" style="width: 100%"><el-table-column prop="id" label="学号" width="180" /><el-table-column prop="name" label="姓名" width="180" /><el-table-column prop="birthday" label="生日" width="180" /><el-table-column prop="address" label="地址" width="180" /><el-table-column label="操作"><template #default="scope"><el-button type="warning" @click="handleEdit(scope.$index, scope.row)">编辑</el-button><el-button type="danger" @click="handleDelete(scope.$index, scope.row)">删除</el-button></template></el-table-column></el-table></div><div style="margin-top: 10px;"><el-pagination layout="total, sizes, prev, pager, next, jumper" v-model:current-page="pageNum"v-model:page-size="pageSize" :page-sizes="[5, 10, 15]" :size="size" :total="total"@size-change="handleSizeChange" @current-change="handleCurrentChange" /></div></el-main></el-container></el-container></div><!-- 添加框 --><el-dialog v-model="addFormVisible" title="添加学生信息" width="500"><el-form :model="studentFrom"><el-form-item label="学生学号"><el-input v-model="studentAddFrom.id" /></el-form-item><el-form-item label="学生姓名"><el-input v-model="studentAddFrom.name" /></el-form-item><el-form-item label="学生生日"><el-input v-model="studentAddFrom.birthday" /></el-form-item><el-form-item label="学生地址"><el-input v-model="studentAddFrom.address" /></el-form-item></el-form><template #footer><div class="dialog-footer"><el-button type="primary" @click="addStudent()">添加</el-button><el-button @click="addFormVisible = false">重置</el-button></div></template></el-dialog><!-- 修改框 --><el-dialog v-model="updateFormVisible" title="修改学生信息" width="500"><el-form :model="studentFrom"><el-form-item label="学生学号"><el-input v-model="studentUpdateFrom.id" /></el-form-item><el-form-item label="学生姓名"><el-input v-model="studentUpdateFrom.name" /></el-form-item><el-form-item label="学生生日"><el-input v-model="studentUpdateFrom.birthday" /></el-form-item><el-form-item label="学生地址"><el-input v-model="studentUpdateFrom.address" /></el-form-item></el-form><template #footer><div class="dialog-footer"><el-button type="primary" @click="updateStudent()">修改</el-button><el-button @click="updateFormVisible = false">重置</el-button></div></template></el-dialog>
</template><style>
.el-menu--horizontal>.el-menu-item:nth-child(1) {margin-right: auto;
}
</style>

–>















<template #footer>

		</div></template>
</el-dialog><!-- 修改框 -->
<el-dialog v-model="updateFormVisible" title="修改学生信息" width="500"><el-form :model="studentFrom"><el-form-item label="学生学号"><el-input v-model="studentUpdateFrom.id" /></el-form-item><el-form-item label="学生姓名"><el-input v-model="studentUpdateFrom.name" /></el-form-item><el-form-item label="学生生日"><el-input v-model="studentUpdateFrom.birthday" /></el-form-item><el-form-item label="学生地址"><el-input v-model="studentUpdateFrom.address" /></el-form-item></el-form><template #footer><div class="dialog-footer"><el-button type="primary" @click="updateStudent()">修改</el-button><el-button @click="updateFormVisible = false">重置</el-button></div></template>
</el-dialog>

这篇关于Vue3、ElementPlus速通的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1128021

相关文章

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

使用Vue.js报错:ReferenceError: “Vue is not defined“ 的原因与解决方案

《使用Vue.js报错:ReferenceError:“Vueisnotdefined“的原因与解决方案》在前端开发中,ReferenceError:Vueisnotdefined是一个常见... 目录一、错误描述二、错误成因分析三、解决方案1. 检查 vue.js 的引入方式2. 验证 npm 安装3.

vue如何监听对象或者数组某个属性的变化详解

《vue如何监听对象或者数组某个属性的变化详解》这篇文章主要给大家介绍了关于vue如何监听对象或者数组某个属性的变化,在Vue.js中可以通过watch监听属性变化并动态修改其他属性的值,watch通... 目录前言用watch监听深度监听使用计算属性watch和计算属性的区别在vue 3中使用watchE

python解析HTML并提取span标签中的文本

《python解析HTML并提取span标签中的文本》在网页开发和数据抓取过程中,我们经常需要从HTML页面中提取信息,尤其是span元素中的文本,span标签是一个行内元素,通常用于包装一小段文本或... 目录一、安装相关依赖二、html 页面结构三、使用 BeautifulSoup javascript

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

【 html+css 绚丽Loading 】000046 三才归元阵

前言:哈喽,大家好,今天给大家分享html+css 绚丽Loading!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 📚一、效果📚二、信息💡1.简介:💡2.外观描述:💡3.使用方式:💡4.战斗方式:💡5.提升:💡6.传说: 📚三、源代码,上代码,可以直接复制使用🎥效果🗂️目录✍️

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06