vue-cli V3.0版本的使用詳解
vue-cli 3.0版本
目前官網(wǎng)上還不是3.0版本,所以需要在github上面學(xué)習(xí)使用:github網(wǎng)站:https://github.com/vuejs/vue-cli/tree/dev/docs
1、項目搭建
(1)、在上面的GitHub網(wǎng)頁中,拉到底部可以看到:
然后在全局中執(zhí)行命令:sudo npm install -g @vue/cli即可。
最后,
vue -V //可以查看到當(dāng)前的vue是3.0版本了
(2)、查看vue 相關(guān)指令
vue --help
查看到的常用指令:
-V:查看版本號
-h:
create:創(chuàng)建一個項目
add: 在項目中創(chuàng)建插件(相當(dāng)于之前的 "npm install")
invoke:在已創(chuàng)建好的項目中調(diào)用插件
inspect:檢查webpack配置
serve:開發(fā)環(huán)境——npm run serve(相當(dāng)于之前的npm run dev)
build:生產(chǎn)環(huán)境,打包上線的
ui:調(diào)用一個ui庫
(3)、創(chuàng)建項目
//執(zhí)行: vue create vue2-demo
在下面的選項中選擇Manually select features,點擊enter后,在顯示的列表中通過上下鍵+空格選擇需要的插件。下面根據(jù)需要選擇即可。
(4)、依次按照下面的步驟創(chuàng)建一個專屬的腳手架,這樣下次創(chuàng)建項目的時候就能直接使用“testnewcli”這個腳手架了。
// vue.config.js 配置說明 // 這里只列一部分,具體配置慘考文檔啊 module.exports = { // baseUrl type:{string} default:'/' // 將部署應(yīng)用程序的基本URL // 將部署應(yīng)用程序的基本URL。 // 默認(rèn)情況下,Vue CLI假設(shè)您的應(yīng)用程序?qū)⒉渴鹪谟虻母夸浵隆? // https://www.my-app.com/。如果應(yīng)用程序部署在子路徑上,則需要使用此選項指定子路徑。例如,如果您的應(yīng)用程序部署在https://www.foobar.com/my-app/,集baseUrl到'/my-app/'. baseUrl: process.env.NODE_ENV === 'production' ? '/online/' : '/', // outputDir: 在npm run build時 生成文件的目錄 type:string, default:'dist' // outputDir: 'dist', // pages:{ type:Object,Default:undfind } /* 構(gòu)建多頁面模式的應(yīng)用程序.每個“頁面”都應(yīng)該有一個相應(yīng)的JavaScript條目文件。該值應(yīng)該是一 個對象,其中鍵是條目的名稱,而該值要么是指定其條目、模板和文件名的對象,要么是指定其條目 的字符串, 注意:請保證pages里配置的路徑和文件名 在你的文檔目錄都存在 否則啟動服務(wù)會報錯的 */ // pages: { // index: { // entry for the page // entry: 'src/index/main.js', // the source template // template: 'public/index.html', // output as dist/index.html // filename: 'index.html' // }, // when using the entry-only string format, // template is inferred to be `public/subpage.html` // and falls back to `public/index.html` if not found. // Output filename is inferred to be `subpage.html`. // subpage: 'src/subpage/main.js' // }, // lintOnSave:{ type:Boolean default:true } 問你是否使用eslint lintOnSave: true, // productionSourceMap:{ type:Bollean,default:true } 生產(chǎn)源映射 // 如果您不需要生產(chǎn)時的源映射,那么將此設(shè)置為false可以加速生產(chǎn)構(gòu)建 productionSourceMap: false, // devServer:{type:Object} 3個屬性host,port,https // 它支持webPack-dev-server的所有選項 devServer: { port: 8085, // 端口號 host: 'localhost', https: false, // https:{type:Boolean} open: true, //配置自動啟動瀏覽器 // proxy: 'http://localhost:4000' // 配置跨域處理,只有一個代理 proxy: { '/api': { target: '<url>', ws: true, changeOrigin: true }, '/foo': { target: '<other_url>' } }, // 配置多個代理 } }
2、添加插件(新版本提供的添加方法)
/添加插件的新方法:vue add vue add vuetify
注:如果我們安裝的是模塊依賴,建議使用npm install ;如果安裝的是組件UI,可能會對當(dāng)前的頁面UI有影響的情況下,就使用vue add方法安裝。
比如上面的vuetify是一個vue的UI庫,會對頁面結(jié)構(gòu)布局產(chǎn)生影響,所以使用vue add 方法;比如我們安裝axios插件,就是用npm install axios就可以了。
3、全局環(huán)境變量
(1)、創(chuàng)建".env"文件:
(2)、在組件中使用全局變量
<template> <div> <h1>{{url}}</h1> </div> </template> <script> export default { data() { return { //調(diào)用全局的環(huán)境配置 url: process.env.VUE_APP_URL }; } }; </script>
4、獨立運行.vue文件
如上圖中,在根目錄下創(chuàng)建的"hello.vue"文件如何獨立運行起來呢?(不依賴腳手架)
//可行方案:安裝插件 sudo npm install -g @vue/cli-service-global //之后執(zhí)行命令: vue serve hello.vue //這樣就可以在瀏覽器看到hello.vue相對應(yīng)的頁面了
5、配置的基礎(chǔ)路徑(vue.config.js)
根目錄創(chuàng)建文件"vue.config.js",
//vue.config.js中配置 module.exports = { baseUrl: "/", //根路徑 outputDir: "dist", //構(gòu)建輸出目錄,執(zhí)行:npm run build后項目打包在dist文件下 assetsDir: "assets", //靜態(tài)資源目錄(js,css,img,fonts) linitOnSave: false, //是否開啟eslint保存檢測,有效值:true || false || "error" }
6、配置跨域請求
在vue.config.js中進(jìn)行配置:
module.exports = { baseUrl: "/", //根路徑 outputDir: "dists", //構(gòu)建輸出目錄 assetsDir: "assets", //靜態(tài)資源目錄(js,css,img,fonts) lintOnSave: false, //是否開啟eslint保存檢測,有效值:true || false || "error" devServer: { open: true, //瀏覽器自動打開頁面 host: '127.0.0.0', //域名 //host: "0.0.0.0", //如果是真機測試,就使用這個IP port: 8060, https: false, hotOnly: false, //熱更新(webpack已實現(xiàn)了,這里false即可) proxy: { //配置跨域 '/api': { target: "http://localhost:2020/api", ws:true, changOrigin:true, pathRewrite:{ '^/api':'' } } } } }
7、加載json數(shù)據(jù)
根目錄下創(chuàng)建data文件夾,里面包含文件data.json,然后在vue.config.js文件中進(jìn)行配置。
const goods = require("./data/goods.json"); module.exports = { baseUrl: "/", //根路徑 outputDir: "dists", //構(gòu)建輸出目錄 assetsDir: "assets", //靜態(tài)資源目錄(js,css,img,fonts) lintOnSave: false, //是否開啟eslint保存檢測,有效值:true || false || "error" devServer: { open: true, //瀏覽器自動打開頁面 host: 'localhost', //域名 port: 8060, https: false, hotOnly: false, //熱更新(webpack已實現(xiàn)了,這里false即可) //加載本地josn數(shù)據(jù) //參見webpack官網(wǎng):https://webpack.docschina.org/configuration/dev-server/#devserver-before before(app) { //http://localhost:8090/myapi/goods app.get("/myapi/goods", (req, res) => { res.json(goods); }) } } }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue+element-ui動態(tài)生成多級表頭的方法
今天小編就為大家分享一篇vue+element-ui動態(tài)生成多級表頭的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08vue3使用Pinia修改state的三種方法(直接修改,$patch,actions)
Vue3?Pinia是一個狀態(tài)管理庫,專門為Vue3設(shè)計優(yōu)化,它提供了一種簡單而強大的方式來管理應(yīng)用程序的狀態(tài),并且與Vue3的響應(yīng)式系統(tǒng)緊密集成,本文給大家介紹了vue3使用Pinia修改state的三種方法,需要的朋友可以參考下2024-03-03VUE3使用Element-Plus時如何修改ElMessage中的文字大小
在使用Element-plus的Elmessage時使用默認(rèn)的size無法滿足我們的需求時,我們可以自定義字體的大小,但是直接重寫樣式后,并沒有起作用,甚至使用::v-deep深度選擇器也沒有效果,本文介紹VUE3使用Element-Plus時如何修改ElMessage中的文字大小,感興趣的朋友一起看看吧2023-09-09使用provide/inject實現(xiàn)跨組件通信的方法
在 Vue 應(yīng)用中,組件間通信是構(gòu)建復(fù)雜應(yīng)用時的一個常見需求,Vue3.x 提供了provide和inject API,讓跨組件通信變得更加簡潔和高效,本文將深入探討如何使用provide和inject在Vue3.x中實現(xiàn)跨組件通信,并通過示例代碼一步步進(jìn)行說明,需要的朋友可以參考下2024-03-03