赞
踩
一,何为Element UI 及 Element Plus?
既然基于Vue,所以可以使用打包工具打包,例如 Vite或WePack
当然Element UI与有React及Angular的版本了。
二、Element UI 与 Element Plus区别?
三、Element UI 与 Element Plus使用
方式一、直接引用方式,引用其CSS及JS,还有vue.js即可:
- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="UTF-8">
- <!-- import CSS -->
- <link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
- </head>
- <body>
- <div id="app">
- <el-button @click="visible = true">Button</el-button>
- <el-dialog :visible.sync="visible" title="Hello world">
- <p>Try Element</p>
- </el-dialog>
- </div>
- </body>
- <!-- import Vue before Element -->
- <script src="https://unpkg.com/vue@2/dist/vue.js"></script>
- <!-- import JavaScript -->
- <script src="https://unpkg.com/element-ui/lib/index.js"></script>
- <script>
- new Vue({
- el: '#app',
- data: function() {
- return { visible: false }
- }
- })
- </script>
- </html>
data:image/s3,"s3://crabby-images/deb9d/deb9d52e6c78f73fbfaadc6e519fd00d286664e1" alt=""
方式二、使用npm加载,以下以Vue3.0为例:
1,创建一个Vue CLI项目:
2,添加element plus引用:
- import { createApp } from 'vue'
- import ElementPlus from 'element-plus'
- import 'element-plus/dist/index.css'
-
- //import zhCn from 'element-plus/dist/locale/zh-cn.mjs'
- import en from 'element-plus/dist/locale/en.mjs'
-
- import App from './App.vue'
-
- const app = createApp(App)
-
- //切换控件内部的语言
- app.use(ElementPlus, {
- // locale:zhCn,
- locale:en,
- })
-
-
- app.mount('#app')
data:image/s3,"s3://crabby-images/deb9d/deb9d52e6c78f73fbfaadc6e519fd00d286664e1" alt=""
3,创建一个控件Helloworld.vue:
- <template>
- <div>
- <el-calendar v-model="value" />
- </div>
- </template>
-
- import { ref } from 'vue'
-
- export default {
- name: 'HelloWorld',
- data: function() {
- return {
- value: ref(new Date())
- }
- },
- props: {
- msg: String
- }
- }
data:image/s3,"s3://crabby-images/deb9d/deb9d52e6c78f73fbfaadc6e519fd00d286664e1" alt=""
4,调用Helloworld.vue:
- <template>
- <HelloWorld msg="Welcome to Your Vue.js App"/>
- </template>
-
- <script>
- import HelloWorld from './components/HelloWorld.vue'
- export default{
- name: 'App',
- components: {
- HelloWorld
- }
- }
- </script>
结果:
注意:
1,使用element plus的时候,发现有些组件不能使用。查到问题,发现script加了lang="ts".
<script lang="ts" setup>
这个是说明这个组件是基于typescript的。去掉这个 lang="ts",很多组件还是可以用的。
2,本人也尝试过安装typescript,但发现安装这个以后,语法需要遵循typescript的语法,且会自动将js文件变成.ts文件。不习惯,所以我又卸载了。
3,vue3.x支持使用export或<script stepup>的方式。但有些初始化数据,还是需要使用<script stepup>(不然会报错):
例如:
- <template>
- <el-table :data="tableData" style="width: 100%">
- <el-table-column prop="date" label="Date" width="180" />
- <el-table-column prop="name" label="Name" width="180" />
- <el-table-column prop="address" label="Address" />
- </el-table>
- </template>
-
-
- <script 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>
data:image/s3,"s3://crabby-images/deb9d/deb9d52e6c78f73fbfaadc6e519fd00d286664e1" alt=""
调用:
- import {createRouter, createWebHashHistory} from "vue-router";
-
- const routes = [
- {
- path: "/",
- component: () => import("../views/HomePage.vue")
- },
- {
- path: "/home",
- component: () => import("../views/HomePage.vue")
- },
- {
- path: "/vip",
- component: () => import("../views/VipPage.vue")
- },
- {
- path: "/404",
- component: () => import("../views/ErrorPage.vue")
- },
- {
- path: "/:catchAll(.*)", // 不识别的path自动匹配404
- redirect: '/404',
- },
- ]
-
-
- const router=createRouter({
- history: createWebHashHistory(),
- routes
- })
-
- export default router;
data:image/s3,"s3://crabby-images/deb9d/deb9d52e6c78f73fbfaadc6e519fd00d286664e1" alt=""
结果:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。