初学vue3+Elementui 项目实战一

一. 安装

  1. 安装@vue/cli

npm install -g @vue/cli

  1. 创建项目

vue create 项目名

  1. 安装Elementui

进入项目根目录 npm i element-ui -S

npm install element-plus --save

  1. 安装Axios,是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中.

进入项目根目录 cnpm i --save axios

  1. 其他第三方的引入,如echarts
    npm install --save 名@版本号

npm install --save echarts@4.9.0

  1. 启动项目

npm install //install dependencies
npm run serve
npm run build //build for production with minification
npm run build --report //build for production and view the bundle analyzer report

你可以通过 vue ui 命令使用 GUI 运行更多的特性脚本

二. 项目结构

45956D0E-E899-4682-8684-2886913A342F.png

node_modules 存放包管理工具下载安装的包的文件夹
public 公共资源
src 源文件
. browserslistrc 项目配置工具
.gitignore git配置
babel.config.js 转码器
package.json 项目依赖文件

  • package.json中:devDependencies中的插件只用于开发环境,dependencies发布到生产环境。

三. 引入

在项目src/main.js中引入依赖
每个 Vue 应用都是通过用 createApp 函数创建一个新的应用实例开始的
vue3全局API的变化,一个新的全局-api-createapp

  • vue3 全局引入,main.js

import { createApp } from "vue";
import App from "./App.vue";
import router from "./router";
import store from "./store";
import ElementUI from 'element-plus'
import 'element-plus/dist/index.css'
const app = createApp(App)
app.use(ElementUI)
app.use(store).use(router).mount("#app")

  • vue2中mian.js

import Vue from "vue";
import App from "./App.vue";
import router from "./router";
import store from "./store";
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
Vue.use(ElementUI)
Vue.config.productionTip = false
new Vue({
router,
store,
render:h => h(App)
}).$mount('#app')

new Vue({
router: router, //路由
store: store, //store 是vuex的实例化对象
render:h => h(App) //一个方法
}).$mount('#app')

ES5的写法:
render:h => h(App)
render:function(createElement){
return createElement(App)
}

h:render中的行参,createElement缩写

ES6的写法: render: createElement => createElement(App)

  • mount
    在Vue构造函数时,需要配置一个el属性,如果没有没有el属性时,可以使用.$mount(‘#app’)进行挂载。

相当于

new Vue({
el: '#app',
router,
render: h => h(App)
});

也可以先得到Virtual DOM,再挂载

var component = new MyComponent().$mount()

document.getElementById('app').appendChild(component.$el)

vue1.x写法

new Vue({
el: '#app',
components: { App }
});

  • render
    一种渲染函数,它比模板更接近编译器,render 函数的优先级高于根据 template 选项或挂载元素的 DOM 内 HTML 模板编译的渲染函数。

  • js与node.js

JS是由ES(ECMAScript)、DOM(浏览器文档对象)、BOM(浏览器对象模型)组成。
其中Node.Js就只有ES,目前浏览器比较流行的版本就是ES6(ES2015),老浏览器的版本基本上都是ES5。所以alert和document不能在Node运行(因为Node没有dom和bom)。

  • ECMAScript 6.0(以下简称 ES6)
    ES6是 JavaScript 语言的下一代标准,已经在 2015 年 6 月正式发布了。它的目标,是使得 JavaScript 语言可以用来编写复杂的大型应用程序,成为企业级开发语言。
    ES6既是一个历史名词,也是一个泛指,含义是5.1版以后的JavaScript的下一代标准,涵盖了ES2015、ES2016、ES2017等等,而ES2015则是正式名称,特指该年发布的正式版本的语言标准。

四. 配置文件

自定义 vue.config.js文件 放在根目录中,和package.json同级

module.exports ={
devServer:{
port:8080,
host:'localhost',
open:true,//配置浏览器自动访问
}
}

五. 路由

  1. 路由在根目录中router文件夹


    F418BE30-B2B8-4DF3-860F-CCAD63549FD3.png
  1. 路由跳转:

import router from '@/router'
router.push('/home')
或者:
this.$router.push('/home')

router为Router的实例,相当于一个全局的路由器对象,进行路由跳转;route相当于当前正在跳转的路由对象。。可以从里面获取name,path,params,query等。

  1. 获取路由信息

created(){
console.log(this.$route)
},

  1. 监听路由变化:

watch:{ //监听
$route(to,from){
console.log(to,from)
}
},

  1. 多级路由


    截屏2021-11-29 上午10.33.06.png

当一进到首页,需要展示的是真正首页的信息,所以:home的redirect:'/index'


截屏2021-11-29 上午10.34.39.png
  1. 路由拦截:访问路由时需要进行校验,校验通过就访问该路由,否则到另一界面


    截屏2021-11-29 下午3.14.07.png

六. 组件的封装与复用

  1. 简单的代码分块
    新建Nav.vue 把已经写好的导航代码移到Nav.vue,并在原文件中导入:

import Nav from './Nav.vue'
export default {
components:{
Nav
}
}
在需要插入组件的代码处:<Nav/>

  1. 组件的封装,传值
    props:父传子的参数
    2.1 把导航分成Nav.vue


    截屏2021-11-29 上午10.43.04.png

刷新界面还能保持选中状态:exact精确匹配

<el-menu :default-active="$route.path" exact

路由的引入:router

<el-menu :default-active="$route.path" exact mode="horizontal" @select="handleSelect" router>

2.2 根据组件名name进行递NavItem.vue


截屏2021-11-29 上午10.45.05.png

2.3 在需要显示路由界面内容的地方:<router-view/>


截屏2021-11-29 上午10.51.13.png

别忘了在需要子级路由的父界面处也插入<router-view/>,比如个人中心下面有卖家操作台子级,需要在个人中心加<router-view/>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容