VUE搭建手機商城心得和遇到的坑
從github上看了一下第一次提交時間是2018年10月22號。到現(xiàn)在將近4個月時間,總算是一點一滴的自己一個人完成了這個使用vue做的商城項目。以前看到別人做的這種項目就很羨慕,想著自己也做一個,曾經(jīng)的憧憬如今總算實現(xiàn)了。一路做過來踩了不少坑,這篇文章就是分享我遇到的這些坑,希望前人爬坑,后人避免。
項目訪問地址xuyuechao.top
vue單頁模式需要注意的坑
1.class樣式?jīng)_突問題
由于是單頁面應(yīng)用。你在每個組件里面寫入的樣式最終都會作用到全局里面去,導致樣式?jīng)_突問題。而每個組件都必須提供一個包裹性質(zhì)的元素,建議這個元素設(shè)置一個單獨的class用于包裹里面的其他class從而避免樣式?jīng)_突
2.靜態(tài)資源倆種處理方式需要理解到位
這個在Vue官方文檔上有詳細的說明,但是我一開始沒有理解到位。走了一些個彎路。這里對Vue官方的內(nèi)容提煉一個重點:
1.public中的內(nèi)容必須用絕對路徑引入也就是以'/'開頭。否則將會被認為是一個模塊引用會被webpack處理。注意:項目如果不是放在根域名下需要如下處理:
<template>
<img src=`${publicPath}MrXu.jpg`>
</template>
<script>
export default {
data() {
return {
publicPath: process.env.BASE_URL
}
}
}
</script>
2.采用相對路徑引入,方式多樣,如:
1.<img src='@/MrXu.jpg'> 2.<img src='~MrXu.jpg'> 3.<img src='./MrXu.jpg'>
第一種方式用到的@代表的是別名的值
第二種方式用到的~其后的任何內(nèi)容都會作為模塊請求被解析。官方說可以引用Node模塊中的資源,這個我還沒用過。等以后用過了有更深的見解會再來補充
第三種方式就是標準的相對路徑引入方式
注意千萬不要用下面這種相對路徑引入方式,因為他不會被webpack處理。而是直接采用的相對路徑尋找文件。而當下的目錄是會被處理的。這種方式一用一個錯
<img src='MrXu.jpg'>
我的建議是盡可能采用相對路徑引入。減少@的使用。因為我經(jīng)過測試發(fā)現(xiàn)css和js文件是不支持@的使用的。
項目中對vue屬性的巧妙運用
1.使用computed監(jiān)聽購物車內(nèi)容的修改
購物車算是整個項目中比較復雜的地方之一了,刪除,添加,選中,取消選中。這些個操作都會對總金額的計算產(chǎn)生影響,所以我用computed監(jiān)聽這些變化完成了總金額的計算以及全選按鈕的變化
computed: {
totalPrice() {
var total = 0;
this.shops.map(value => {
if (value.check) total += value.num * value.price;
});
return total;
},
isAllCheck() {
var newLength = this.shops.filter(value => {
return value.check;
}).length;
return newLength === this.shops.length ? true : false;
}
}
2.使用filter完成了對訂單狀態(tài)的顯示
項目中訂單的狀態(tài)多大7種,剛開始在html里面使用了三目運算符做的判斷顯示,顯示效果極差,而且維護困難。但是采用filter不僅漂亮的多,后期的維護以及擴展都一幕了然
filters: {
statusToText(value) {
let reValue;
switch (value) {
case 1:
reValue = "代付款";
break;
case 2:
reValue = "代發(fā)貨";
break;
case 3:
reValue = "待收貨";
break;
case 4:
reValue = "已完成";
break;
case 5:
reValue = "已取消";
break;
case 6:
reValue = "售后處理";
break;
}
return reValue;
}
}
感言
做完這個項目收獲真的蠻頗多的,像route的母子路由,路由懶加載,別名設(shè)置,路由攔截,vuex中actions,mutations,state的區(qū)別,vue的生命周期,父子組件傳值,watch,computed等等。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue 解決在element中使用$notify在提示信息中換行問題
這篇文章主要介紹了Vue 解決在element中使用$notify在提示信息中換行問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11
vue框架和react框架的區(qū)別以及各自的應(yīng)用場景使用
這篇文章主要介紹了vue框架和react框架的區(qū)別以及各自的應(yīng)用場景使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10
vueCli?4.x升級5.x報錯:Progress?Plugin?Invalid?Options的解決方法
本文主要介紹了vueCli?4.x升級5.x報錯:Progress?Plugin?Invalid?Options的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2024-01-01
vue props對象validator自定義函數(shù)實例
今天小編就為大家分享一篇vue props對象validator自定義函數(shù)實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11
詳解Vue CLI 3.0腳手架如何mock數(shù)據(jù)
這篇文章主要介紹了詳解Vue CLI 3.0腳手架如何mock數(shù)據(jù),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11

