国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

vue-cli +webpack+vue-router 踩坑記

OpenDigg / 3095人閱讀

摘要:其中定義了一些命令,還記得我們初始化項(xiàng)目完成后執(zhí)行其實(shí)就是執(zhí)行簡(jiǎn)單的來(lái)說(shuō)是運(yùn)行時(shí)依賴生產(chǎn)環(huán)境,是開(kāi)發(fā)時(shí)的依賴開(kāi)發(fā)環(huán)境相應(yīng)的在安裝包時(shí),有兩種命令參數(shù)可以把它們的信息寫(xiě)入文件,會(huì)把依賴包名稱添加到文件鍵下,則添加到文件鍵下。

這次主要是記錄下自己在做vue-cli +webpack +vue-router 的經(jīng)歷 以及一些踩過(guò)的坑,算是做一個(gè)簡(jiǎn)單的總結(jié) 一.vue的基本介紹 1)漸進(jìn)式的框架

它是漸進(jìn)的,沒(méi)有強(qiáng)主張,框架做分層設(shè)計(jì),每層都可選,不同層可以靈活接入其他方案。你可以在原有大系統(tǒng)的上面,把一兩個(gè)組件改用它實(shí)現(xiàn),當(dāng)jQuery用;也可以整個(gè)用它全家桶開(kāi)發(fā),當(dāng)Angular用;還可以用它的視圖,搭配你自己設(shè)計(jì)的整個(gè)下層用。你可以在底層數(shù)據(jù)邏輯的地方用OO和設(shè)計(jì)模式的那套理念,也可以函數(shù)式,都可以。
總的來(lái)說(shuō),它給你提供足夠的optional,但并不主張很多required。

2)vue中兩個(gè)核心點(diǎn)

1.響應(yīng)的數(shù)據(jù)綁定
數(shù)據(jù)變化=> 自動(dòng)更新視圖 利用Object.definedProperty中的 setter/getter代理數(shù)據(jù),監(jiān)控對(duì)數(shù)據(jù)的操作
具體實(shí)現(xiàn):把一個(gè)普通的js對(duì)象傳給vue實(shí)例的data選項(xiàng) vue將遍歷此對(duì)象所有的屬性,并使用Object.defineProperty 把這些屬性全部轉(zhuǎn)為getter/setter 。vue內(nèi)部會(huì)對(duì)數(shù)據(jù)進(jìn)行劫持操作,進(jìn)而追蹤依賴,在屬性被訪問(wèn)和修改時(shí),通知變化。
2.組合的視圖組件
根據(jù)UI頁(yè)面映射為組件樹(shù),劃分不同的組件可維護(hù),可重用,可測(cè)試

3)虛擬DOM

利用在內(nèi)存中生成與DOM與之對(duì)應(yīng)的數(shù)據(jù)結(jié)構(gòu),這個(gè)結(jié)構(gòu)稱之為虛擬DOM.當(dāng)數(shù)據(jù)發(fā)生變化的時(shí)候,能智能地計(jì)算出重新渲染組件的最小代價(jià)并應(yīng)用到DOM操作上

二.項(xiàng)目初始化 1)vue官網(wǎng)上的步驟

全局安裝 vue-cli
npm install --global vue-cli
vue init webpack my-project
cd my-project
npm install
npm run dev

-g :代表全局安裝
這樣項(xiàng)目就創(chuàng)建好了,因?yàn)閚pm源是在國(guó)外,如果是要使用國(guó)內(nèi)的鏡像:
淘寶npm鏡像 搜索地址:http://npm.taobao.org/
registry地址:http://registry.npm.taobao.org/

使用cnmp

npm install -g cnpm --registry=https://registry.npm.taobao.org

//
其中需要注意的是 使用npm會(huì)需要先下載node.js

安裝過(guò)程中,會(huì)提示 是否使用eslint,eslint算是一個(gè)代碼語(yǔ)法規(guī)范檢查的工具,不同意就不會(huì)把檢查語(yǔ)法規(guī)范的功能加進(jìn)webpack編譯的流程里
個(gè)人建議是選擇n 這樣避免了很多格式錯(cuò)誤

自動(dòng)打開(kāi)瀏覽器:只要在項(xiàng)目根目錄下找到package.json,然后打開(kāi)該文件,在文件中的script腳本命令的dev行加入--open就可以了。如圖所示。然后重新啟動(dòng)項(xiàng)目就可以自動(dòng)打開(kāi)瀏覽器了

2)項(xiàng)目結(jié)構(gòu)

在src路徑下

1.packagejson文件 packagejson文件是項(xiàng)目的配置文件,定義了項(xiàng)目的基本信息以及項(xiàng)目的相關(guān)包依賴,npm運(yùn)行命令等,位于項(xiàng)目根目錄下。

其中“scripts”定義了一些npm命令,還記得我們初始化項(xiàng)目完成后執(zhí)行npm run dev 其實(shí)就是執(zhí)行
webpack-dev-server --inline --progress --config build/webpack.dev.conf.js

2.dependencies VS devDependencies
簡(jiǎn)單的來(lái)說(shuō)dependencies是運(yùn)行時(shí)依賴(生產(chǎn)環(huán)境),devDependencies是開(kāi)發(fā)時(shí)的依賴(開(kāi)發(fā)環(huán)境)
相應(yīng)的npm install 在安裝 npm 包時(shí),有兩種命令參數(shù)可以把它們的信息寫(xiě)入 package.json 文件,--save 會(huì)把依賴包名稱添加到 package.json 文件 dependencies 鍵下,--save-dev 則添加到 package.json 文件 devDependencies 鍵下。
舉個(gè)例子,比如我們項(xiàng)目要引用jQuery,因?yàn)閖Query部署到線上環(huán)境也要使用(生產(chǎn)環(huán)境),所以安裝jQuery的命令為npm install jQuery --save 這時(shí)候 dependencies 鍵下就會(huì)多了一個(gè)jQuery包
3.基礎(chǔ)配置文件
webpack.base.conf.js基礎(chǔ)的 webpack 配置文件主要根據(jù)模式定義了入口出口,以及處理 vue, babel 等的各種模塊,是最為基礎(chǔ)的部分。其他模式的配置文件以此為基礎(chǔ)通過(guò) webpack-merge 合并。
4.main.js .src/main.js文件解讀 是webpack入口文件
5.asset文件夾下面的是靜態(tài)資源 img font等等
6.components文件夾下面是.vue的組件
7.router文件夾下面的是index.js設(shè)置路由
8.App.vue 所有自己寫(xiě)的組件,都是在這個(gè)組件之上運(yùn)行了

三.項(xiàng)目創(chuàng)建完成 文件的配置 引入 1)介紹目前經(jīng)常會(huì)用到的三種ui框架

1.首先 假設(shè)我們要使用的ui框架為mintui 那么參照mintui官方文檔
先是npm install mint-ui -S

然后在App.vue中進(jìn)行引入
// 引入全部組件
import Vue from "vue";
import Mint from "mint-ui";
Vue.use(Mint);


2.同理 可以看到注釋中寫(xiě)著 使用Amazeui vue版本的引入方法
npm install amaze-vue --save

import Vue from "vue";

import AmazeVue from "amaze-vue";
import "amaze-vue/dist/amaze-vue.css";

Vue.use(AmazeVue);

3.第三中ui semantic-ui 相比較而言 會(huì)麻煩一點(diǎn)
首先安裝jquery
npm install --save jquery
然后在 webpack.dev.config.js 文件中,添加
// plugins 區(qū)塊內(nèi)
new webpack.ProvidePlugin({
$ : "jquery",
jQuery : "jquery",
"window.jQuery": "jquery",
"root.jQuery" : "jquery"
})
隨后安裝 semantic-ui-css
npm install semantic-ui-css --save
之后在 webpack.base.config.js 文件中添加,
resolve : {

extensions: ["", ".js", ".vue"],
fallback  : [path.join(__dirname, "../node_modules")],
alias     : {
  "vue"       : "vue/dist/vue.common.js",
  "src"       : path.resolve(__dirname, "../src"),
  "assets"    : path.resolve(__dirname, "../src/assets"),
  "components": path.resolve(__dirname, "../src/components"),
  // Semantic-UI
  "semantic"  : path.resolve(__dirname, "../node_modules/semantic-ui-css/semantic.min.js")
}

}
隨后在 webpack.dev.config.js 文件中,添加

plugins: [

new webpack.ProvidePlugin({
  $              : "jquery",
  jQuery         : "jquery",
  "window.jQuery": "jquery",
  "root.jQuery"  : "jquery",
  // Semantic-UI
  semantic     : "semantic-ui-css",
  Semantic     : "semantic-ui-css",
  "semantic-ui": "semantic-ui-css"
}),



最后在App.vue中引入
import semantic from "semantic"
import "../node_modules/semantic-ui-css/semantic.min.css"

同樣也可以從上面看出,jquery的全局引入的方法

2)項(xiàng)目中的公共文件

對(duì)于項(xiàng)目中會(huì)公共使用到的頭部 尾部等文件可以統(tǒng)一在App.vue文件中引入


注意起名的時(shí)候不能寫(xiě)成關(guān)鍵字 像footer等h5自帶的標(biāo)簽
從上圖中可以看出來(lái) tabbar為公共文件而 router-view則為通過(guò)路由引入的組件
此外 因?yàn)榱?xí)慣了 使用scss 需要
npm install sass-loader node-sass style-loader --save-dev

3)路由的設(shè)置


從圖上可以看出 先是使用import把需要使用路由的組件引入 需要注意的就是 from 后面需要帶上"@/"
其次是關(guān)于嵌套路由的設(shè)置


嵌套路由不能寫(xiě)成"/second"的形式 會(huì)被認(rèn)為是從根目錄下引入
第三點(diǎn)是對(duì)于 meta的設(shè)置 因?yàn)槭菃雾?yè)面應(yīng)用 所以切換時(shí)需要改變頁(yè)面的title keyword description

需要結(jié)合main.js中的router.beforeEach方法使用

4)跨域設(shè)置

當(dāng)跨域無(wú)法請(qǐng)求的時(shí)候我們可以修改工程下config文件夾下的index.js中的dev:{}部分。

將target設(shè)置為我們需要訪問(wèn)的域名,然后在main.js中設(shè)置全局屬性:Vue.prototype.HOST = "/api"
至此,我們就可以在全局使用這個(gè)域名了,如下:
var url = this.HOST + "/movie/in_theaters"

this.$http.get(url).then(res => {
  this.movieList = res.data.subjects;
},res => {
  console.info("調(diào)用失敗");
});

最后項(xiàng)目運(yùn)行
npm run dev
項(xiàng)目發(fā)布
npm run build

四.結(jié)尾

差不多這次需要記錄的就這么多,因?yàn)楣厩岸司臀乙粋€(gè)人,很多東西都是網(wǎng)上查以及問(wèn)的人,感覺(jué)坑很多,很多也不是很熟悉,用到的都只是小部分,所以以后隨時(shí)補(bǔ)充。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/90108.html

相關(guān)文章

  • vue-cli3.x 新特性及踩坑記

    摘要:前言都到了,所以是時(shí)候玩轉(zhuǎn)一下的新特性了。安裝的包名稱由改成了。方法一原因的配置改變了,導(dǎo)致正確的不能用。打開(kāi)終端,切換到根路徑文件里面修改為方法二是默認(rèn)路徑修改了路徑會(huì)出現(xiàn)錯(cuò)誤。按上面的方法修改完,再全局卸載果然就成功了。 showImg(https://segmentfault.com/img/remote/1460000016423946); 前言 vue-cli 都到 3.0....

    xiaoqibTn 評(píng)論0 收藏0
  • 關(guān)于Vue2一些值得推薦的文章 -- 五、六月份

    摘要:五六月份推薦集合查看最新的請(qǐng)點(diǎn)擊集前端最近很火的框架資源定時(shí)更新,歡迎一下。蘇幕遮燎沈香宋周邦彥燎沈香,消溽暑。鳥(niǎo)雀呼晴,侵曉窺檐語(yǔ)。葉上初陽(yáng)乾宿雨,水面清圓,一一風(fēng)荷舉。家住吳門(mén),久作長(zhǎng)安旅。五月漁郎相憶否。小楫輕舟,夢(mèng)入芙蓉浦。 五、六月份推薦集合 查看github最新的Vue weekly;請(qǐng)::點(diǎn)擊::集web前端最近很火的vue2框架資源;定時(shí)更新,歡迎 Star 一下。 蘇...

    sutaking 評(píng)論0 收藏0
  • 關(guān)于Vue2一些值得推薦的文章 -- 五、六月份

    摘要:五六月份推薦集合查看最新的請(qǐng)點(diǎn)擊集前端最近很火的框架資源定時(shí)更新,歡迎一下。蘇幕遮燎沈香宋周邦彥燎沈香,消溽暑。鳥(niǎo)雀呼晴,侵曉窺檐語(yǔ)。葉上初陽(yáng)乾宿雨,水面清圓,一一風(fēng)荷舉。家住吳門(mén),久作長(zhǎng)安旅。五月漁郎相憶否。小楫輕舟,夢(mèng)入芙蓉浦。 五、六月份推薦集合 查看github最新的Vue weekly;請(qǐng)::點(diǎn)擊::集web前端最近很火的vue2框架資源;定時(shí)更新,歡迎 Star 一下。 蘇...

    khs1994 評(píng)論0 收藏0
  • 從零開(kāi)始通過(guò)vue-cli搭建項(xiàng)目

    npm i -g vue -cli 全局安裝vue-cli腳手架【按需安裝】 vue init webpack my-project 構(gòu)建項(xiàng)目 cd my-project 打開(kāi)項(xiàng)目目錄,到項(xiàng)目目錄路徑 npm install 可以使用cnpm i 安裝依賴包 npm run dev 將本地項(xiàng)目跑起來(lái)接下來(lái)就是做一些配置項(xiàng) package.json webpack-dev-server...

    104828720 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<