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

資訊專欄INFORMATION COLUMN

Vue+Vue-router+Vuex項目實戰(zhàn)

Chiclaim / 2285人閱讀

摘要:實現(xiàn)電商網(wǎng)站效果展示下載代碼安裝依賴啟動項目運行環(huán)境需求分析登錄頁面商品列表頁網(wǎng)站首頁購物車頁實現(xiàn)結算商品詳情頁可按顏色品牌對商品進行篩選,單擊選中,再次點擊取消根據(jù)價格進行升序降序銷量降序排列商品列表顯示圖片名稱銷量顏色單價實時顯示

shopping

vue + vue-router + vuex實現(xiàn)電商網(wǎng)站

效果展示

install

下載代碼: git clone https://github.com/chenchangyuan/shopping.git

安裝依賴: npm install

啟動項目: npm run dev

運行環(huán)境: node v9.11.1 npm 5.6.0
需求分析

登錄頁面、商品列表頁(網(wǎng)站首頁)、購物車頁(實現(xiàn)結算)、商品詳情頁

可按顏色、品牌對商品進行篩選,單擊選中,再次點擊取消

根據(jù)價格進行升序降序、銷量降序排列

商品列表顯示圖片、名稱、銷量、顏色、單價

實時顯示購物車數(shù)量(商品類別數(shù))

購物車頁面實現(xiàn)商品總價、總數(shù)進行結算,優(yōu)惠券打折

數(shù)據(jù)存儲 & 數(shù)據(jù)處理

product.js存放商品數(shù)據(jù)(生產(chǎn)環(huán)境需通過接口調(diào)用獲取數(shù)據(jù))

{
    id: 1,
    name: "AirPods",
    brand: "Apple",
    image: "/src/images/airPods.jpg",
    imageDetail: "/src/images/airPods_detail.jpg",
    sales: 10000,
    cost: 1288,
    color: "白色"
},

window.localStorage實現(xiàn)數(shù)據(jù)存儲與驗證

let username = window.localStorage.getItem("username");
let password = window.localStorage.getItem("password");
if(!util.trim(this.username) || !util.trim(this.username) ){
    window.alert("賬號或密碼不能為空");
    return;
}
if(username === this.username && password === this.password){
    this.login = false;
    window.localStorage.setItem("loginStatus", "login");
    this.$store.commit("getUser", this.username);
    window.alert("登陸成功,確定進入網(wǎng)站首頁");
    window.location.href = "/list";
}else{
    window.alert("賬號或密碼錯誤");
}

數(shù)據(jù)過濾與排序處理

filteredAndOrderedList(){
    //拷貝原數(shù)組
    let list = [...this.list];
    //品牌過濾
    if(this.filterBrand !== ""){
        list = list.filter(item => item.brand === this.filterBrand);
    }
    //顏色過濾
    if(this.filterColor !== ""){
        list = list.filter(item => item.color === this.filterColor);
    }
    //排序
    if(this.order !== ""){
        if(this.order === "sales"){
            list = list.sort((a, b) => b.sales - a.sales);
        }else if(this.order === "cost-desc"){
            list = list.sort((a, b) => b.cost - a.cost);
        }else if(this.order === "cost-asc"){
            list = list.sort((a, b) => a.cost - b.cost);
        }
    }
    return list;
}

實時顯示應付總額與商品數(shù)

//購物車商品總數(shù)
countAll(){
    let count = 0;
    this.cartList.forEach(item => {
        count += item.count;
    });
    return count;
},
//購物車商品總價
costAll(){
    let cost = 0;
    this.cartList.forEach(item => {
        cost += this.productDictList[item.id].cost * item.count;
    });
    return cost;
}

購物車結算處理

//通知Vuex,完成下單
handleOrder(){
    this.$store.dispatch("buy").then(() => {
        window.alert("購買成功");
    })
},
vue-router & vuex

vue-router路由管理/src/views/目錄下的vue組件進行設置,router-views掛載所有路由,登錄界面與商品列表頁面之間header做隱藏顯示處理,登錄狀態(tài)下刷新頁面跳轉至列表頁,其他頁面設置默認跳轉

跳轉處理

const router = new VueRouter(RouterConfig);

//跳轉前設置title
router.beforeEach((to, from, next) => {
    window.document.title = to.meta.title;
    next();
});
//跳轉后設置scroll為原點
router.afterEach((to, from, next) => {
    window.scrollTo(0, 0);
});

routers配置

//商品列表路由配置
const routers = [
    {
        path: "/list",
        meta: {
            title: "商品列表"
        },
        component: (resolve) => require(["./views/list.vue"], resolve)
    },
    {
        path: "/product/:id",
        meta: {
            title: "商品詳情"
        },
        component: (resolve) => require(["./views/product.vue"], resolve)
    },
    {
        path: "/cart",
        meta: {
            title: "購物車"
        },
        component: (resolve) => require(["./views/cart.vue"], resolve)
    },
    {
        path: "/login/:loginStatus",
        meta: {
            title: "登錄注冊"
        },
        component: (resolve) => require(["./views/login.vue"], resolve)
    },
    {
        path: "*",
        redirect: "/login/login"
    }
];
export default routers;

vuex狀態(tài)管理,各組件共享數(shù)據(jù)在state中設置,mutation實現(xiàn)數(shù)據(jù)同步,action異步加載

//配置Vuex狀態(tài)管理
const store = new Vuex.Store({
    state: {
        //商品列表信息
        productList: [],
        //購物車數(shù)據(jù),數(shù)組形式,數(shù)據(jù)元素為對象(商品id,購買數(shù)量count)
        cartList: [],
        //當前用戶賬號
        username: window.localStorage.getItem("username"),
        //登錄狀態(tài)
        loginStatus: !!window.localStorage.getItem("loginStatus"),
    },
    getters: {
        //品牌、顏色篩選
        brands: state => {
            const brands = state.productList.map(item => item.brand);
            return util.getFilterArray(brands);
        },
        colors: state => {
            const colors = state.productList.map(item => item.color);
            return util.getFilterArray(colors);
        }
    },
    //mutations只能以同步方式
    mutations: {
        //添加商品列表
        setProductList(state, data){
            state.productList = data;
        },
        //添加購物車
        addCart(state, id){
            const isAdded = state.cartList.find(item => item.id === id);
            //如果不存在設置購物車為1,存在count++
            if(isAdded){
                isAdded.count++;
            }else{
                state.cartList.push({
                    id: id,
                    count: 1
                })
            }
        },
        //修改購物車商品數(shù)量
        editCartCount(state, payload){
            const product = state.cartList.find(item => item.id === payload.id);
            product.count += payload.count;
        },
        //刪除購物車商品
        deleteCart(state, id){
            const index = state.cartList.findIndex(item => item.id === id);
            state.cartList.splice(index, 1)
        },
        //清空購物車
        emptyCart(state){
            state.cartList = [];
        },
        getUser(state, username){
            console.log("username",username)
            state.username = username;
        },
        getLoginStatus(state, flag){
            state.loginStatus = flag;
        }
    },
    actions: {
        //異步請求商品列表,暫且使用setTimeout
        getProductList(context){
            setTimeout(() => {
                context.commit("setProductList", product_data)
            }, 500);
        },
        //購買
        buy(context){
            //生產(chǎn)環(huán)境使用ajax請求服務端響應后再清空購物車
            return new Promise(resolve => {
                setTimeout(() => {
                    context.commit("emptyCart");
                    resolve();
                }, 500);
            });
        },
    }
});
后記

項目地址: 閱讀完本文如果對vue的理解有所幫助,請給顆star,謝謝~

筆者個人微信 gm4118679254 歡迎加好友一起交流技術

參考資料

Vue.js實戰(zhàn)
Vue.js

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

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/117535.html

相關文章

  • Vue+Vue-router+Vuex項目實戰(zhàn)

    摘要:實現(xiàn)電商網(wǎng)站效果展示下載代碼安裝依賴啟動項目運行環(huán)境需求分析登錄頁面商品列表頁網(wǎng)站首頁購物車頁實現(xiàn)結算商品詳情頁可按顏色品牌對商品進行篩選,單擊選中,再次點擊取消根據(jù)價格進行升序降序銷量降序排列商品列表顯示圖片名稱銷量顏色單價實時顯示 shopping vue + vue-router + vuex實現(xiàn)電商網(wǎng)站 效果展示 showImg(https://user-gold-cdn.xi...

    zlyBear 評論0 收藏0
  • Vue+Vue-router+Vuex項目實戰(zhàn)

    摘要:實現(xiàn)電商網(wǎng)站效果展示下載代碼安裝依賴啟動項目運行環(huán)境需求分析登錄頁面商品列表頁網(wǎng)站首頁購物車頁實現(xiàn)結算商品詳情頁可按顏色品牌對商品進行篩選,單擊選中,再次點擊取消根據(jù)價格進行升序降序銷量降序排列商品列表顯示圖片名稱銷量顏色單價實時顯示 shopping vue + vue-router + vuex實現(xiàn)電商網(wǎng)站 效果展示 showImg(https://user-gold-cdn.xi...

    Half 評論0 收藏0
  • 手挽手帶你學VUE:四檔 Vue-cli3 Vuex Vue-router

    摘要:安裝過后到命令行執(zhí)行檢查版本,如果彈出版本的話恭喜你安裝成功,我們開始進行下面的步驟了。全局安裝的包名稱由改成了。如果你已經(jīng)全局安裝了舊版本的或,你需要先通過卸載它。中的非常類似于事件每個都有一個字符串的事件類型和一個回調(diào)函數(shù)。 視頻教程 由于思否不支持視頻外鏈,視頻請移步http://www.henrongyi.top 你能學到什么 在這一期的學習進度中,我們會開始學習在我們工作開...

    Sourcelink 評論0 收藏0
  • 手挽手帶你學VUE:四檔 Vue-cli3 Vuex Vue-router

    摘要:安裝過后到命令行執(zhí)行檢查版本,如果彈出版本的話恭喜你安裝成功,我們開始進行下面的步驟了。全局安裝的包名稱由改成了。如果你已經(jīng)全局安裝了舊版本的或,你需要先通過卸載它。中的非常類似于事件每個都有一個字符串的事件類型和一個回調(diào)函數(shù)。 視頻教程 由于思否不支持視頻外鏈,視頻請移步http://www.henrongyi.top 你能學到什么 在這一期的學習進度中,我們會開始學習在我們工作開...

    AlphaWallet 評論0 收藏0
  • 前端面試題總結(js、html、小程序、React、ES6、Vue、算法、全棧熱門視頻資源)

    摘要:并總結經(jīng)典面試題集各種算法和插件前端視頻源碼資源于一身的文檔,優(yōu)化項目,在瀏覽器端的層面上提升速度,幫助初中級前端工程師快速搭建項目。 本文是關注微信小程序的開發(fā)和面試問題,由基礎到困難循序漸進,適合面試和開發(fā)小程序。并總結vue React html css js 經(jīng)典面試題 集各種算法和插件、前端視頻源碼資源于一身的文檔,優(yōu)化項目,在瀏覽器端的層面上提升速度,幫助初中級前端工程師快...

    pumpkin9 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<