提示:vue2依赖node版本8.0以上
文章目录
- 前言
- 一、创建项目基于vue-cli
- 二、创建项目基于@vue/cli
- 三、对吧两种创建方式
- [四、安装Element ui并引入](#四、安装Element ui并引入)
- 五、配置路由跳转
- 四、效果
- 五、参考文档
- 总结
前言
使用@vue/cli脚手架vue create创建
使用vue-cli脚手架vue init webpack创建
一、创建项目基于vue-cli
1、查看nodejs版本
c
node -v
data:image/s3,"s3://crabby-images/9aa42/9aa42cd37e9a56ee0a20835bc8a88760e8d61489" alt=""
2、全局安装vue脚手架和webpack脚手架
c
npm install -g vue-cli
npm install -g webpack
npm install -g webpack-cli
3、新建vue2项目
c
vue init webpack test-vue2-webpack
data:image/s3,"s3://crabby-images/ec258/ec2589fe5d47de8d4b6d04c2f79f4d41f33195f4" alt=""
创建选项除了,Install vue-router??选择是,其他选择的否
data:image/s3,"s3://crabby-images/cf5e0/cf5e0b1a199dc27ec920a3dd3dc6c6cd067584c2" alt=""
4、安装依赖并启动文件
c
cd test-vue2-webpack
npm install
npm run dev
data:image/s3,"s3://crabby-images/bdbce/bdbce8f4a246dab2316acdd2f69a2ee7afc2d5bf" alt=""
5、预览
6、目录结构
二、创建项目基于@vue/cli
1、如果安装了vue-cli,需要先卸载vue-cli
c
npm uninstall -g vue-cli
data:image/s3,"s3://crabby-images/c7c4f/c7c4fd7489bbf9790fa45f6bf01fbe67feef9a0f" alt=""
2、全局安装vue脚手架和webpack脚手架
c
npm install -g @vue/cli
npm install -g webpack
npm install -g webpack-cli
3、新建vue2项目
c
vue create test-vue2-create
data:image/s3,"s3://crabby-images/f503e/f503eb1c1629126dc89d8fc14d0f94222735529a" alt=""
创建选项选择vue2项目
4、启动文件
这样创建的项目,不需要npm install,直接可启动
c
cd test-vue2-create
npm run serve
data:image/s3,"s3://crabby-images/bdbce/bdbce8f4a246dab2316acdd2f69a2ee7afc2d5bf" alt=""
5、预览
6、目录结构
三、对吧两种创建方式
1、使用@vue/cli脚手架vue create创建项目,结构更简单,创建完直接安装完依赖,不需要手动npm install
2、使用@vue/cli脚手架vue create创建项目,安装的依赖更少
3、启动方式,启动方式可以自己配置,看个人习惯
c
//vue-cli
npm run dev
//@vue/cli
npm run serve
4、package.json配置npm run dev启动命令
四、安装Element ui并引入
安装和引用element-ui方式都相同,这里拿vue create 的test-vue2-create项目做演示
1、安装
c
npm i element-ui -S
data:image/s3,"s3://crabby-images/9c877/9c87781a3ef3c2894526a3df619d74a07a44968f" alt=""
2、引入
main.js
c
import Vue from 'vue'
import App from './App.vue'
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
Vue.config.productionTip = false
Vue.use(ElementUI);
new Vue({
render: h => h(App),
}).$mount('#app')
data:image/s3,"s3://crabby-images/447f2/447f2bcee03e7ff3948794ca0cafdb672776e489" alt=""
3、按需引入
c
npm install babel-plugin-component -D
data:image/s3,"s3://crabby-images/5c532/5c532f38efd6f65de98a7bd5167aa21a8b476fec" alt=""
main.js
c
import Vue from 'vue'
import App from './App.vue'
import 'element-ui/lib/theme-chalk/index.css';
//全部引用
// import ElementUI from 'element-ui';
// Vue.use(ElementUI);
//按需引用
import { Button,Input } from 'element-ui';
Vue.use(Button).use(Input);
Vue.config.productionTip = false
new Vue({
render: h => h(App),
}).$mount('#app')
4、配置babel.config.js
babel.config.js
c
module.exports = {
presets: [
'@vue/cli-plugin-babel/preset'
],
plugins: [
[
"component",
{
"libraryName": "element-ui",
"styleLibraryName": "theme-chalk"
}
]
]
}
data:image/s3,"s3://crabby-images/d8ee1/d8ee1b41eb3427e951f80bb537b42961f2c9daad" alt=""
5、修改app.vue
c
<template>
<div id="app">
<el-button>按钮</el-button>
<el-input placeholder="输入框"></el-input>
</div>
</template>
<script>
export default {
name: 'App',
components: {}
}
</script>
<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
margin-top: 60px;
}
</style>
data:image/s3,"s3://crabby-images/a89b1/a89b10c02f8e9b66c1d1f82f3b3ed39ba466d263" alt=""
6、启动项目预览
c
npm run dev
data:image/s3,"s3://crabby-images/bfe91/bfe91155c3e54ce318be4d5a6e9d272f96e605a1" alt=""
五、配置路由跳转
1、安装vue-router
c
npm install vue-router -S
data:image/s3,"s3://crabby-images/d10be/d10bee7f0b062841dbd2ed0e34038acbba2199d1" alt=""
2、关闭创建vue component检查
vue.config.js
c
const { defineConfig } = require('@vue/cli-service')
module.exports = defineConfig({
transpileDependencies: true,
lintOnSave: false
})
data:image/s3,"s3://crabby-images/8f031/8f031e3bffcb29997610252b168589b71481aaab" alt=""
3、新建src/router/index.js
c
import Vue from 'vue';
import Router from 'vue-router';
import Home from '@/components/Home.vue';
import My from '@/components/My.vue';
Vue.use(Router);
const routes = [
{ path: '/', component: Home },
{ path: '/my', component: My }
]
export default new Router({ routes })
data:image/s3,"s3://crabby-images/b504a/b504ab12728298eec490cf1230af6c217c7ef62a" alt=""
4、新建src/components/Home.vue和src/components/My.vue
Home.vue
c
<template>
<div class="home">
<h1>Home页面</h1>
<el-button @click="$router.push('/my')">去My</el-button>
</div>
</template>
<script>
export default {
name: 'Home',
}
</script>
<style scoped>
</style>
My.vue
c
<template>
<div class="my">
<h1>My页面</h1>
<el-button @click="$router.push('/')">去Home</el-button>
</div>
</template>
<script>
export default {
name: 'My',
}
</script>
<style scoped>
</style>
data:image/s3,"s3://crabby-images/7f6c5/7f6c5f78de413293ec71554d223532193a4a9c07" alt=""
5、修改App.vue
c
<template>
<div id="app">
<router-view></router-view>
</div>
</template>
<script>
export default {
name: 'App',
components: {}
}
</script>
<style>
</style>
data:image/s3,"s3://crabby-images/0ba37/0ba3771480cae8d3130698d3b8da95c6abc045b8" alt=""
6、修改main.js
c
import Vue from 'vue'
import App from './App.vue'
import 'element-ui/lib/theme-chalk/index.css';
import router from './router'
//全部引用
// import ElementUI from 'element-ui';
// Vue.use(ElementUI);
//按需引用
import { Button,Input } from 'element-ui';
Vue.use(Button).use(Input);
Vue.config.productionTip = false
new Vue({
render: h => h(App),
router
}).$mount('#app')
data:image/s3,"s3://crabby-images/07d0a/07d0a14bd6fdb690ec377259cd94f7c811986721" alt=""
四、效果
五、参考文档
1、vue2官网
总结
踩坑路漫漫长@~@