vue實現(xiàn)商品詳情頁功能之商品選項卡
本文實例為大家分享了vue實現(xiàn)商品詳情頁功能之商品選項卡的具體代碼,供大家參考,具體內(nèi)容如下
用戶點擊商品進入商品詳情頁,默認顯示第一個小圖對應的大圖,然后鼠標滑到小圖上,大圖也會發(fā)生改變,實現(xiàn)效果如下:


實現(xiàn)代碼:
shopitem.vue的template(HTML),上面是大圖,下面是小圖,鼠標滑動到小圖上,觸發(fā)getUrl事件(參數(shù)是小圖的show屬性,索引):

item.json文件(我的數(shù)據(jù)文件,默認第一個小圖的show為true,默認大圖顯示第一張。大圖和小圖的路徑一樣的,只是css控制的圖片大小不一樣):

shopitem.vue的<script>方法(fechData()是用vue-resource請求后臺數(shù)據(jù),即本地json文件。本地json文件存放在static文件夾里。)



vuex(狀態(tài)管理)的store.js文件代碼,實現(xiàn)數(shù)據(jù)持久化:
//store 相當于倉庫 一個組件使用并改變數(shù)據(jù),另一個組件使用的是前一個組件改變后的數(shù)據(jù)
//所以這就是vuex 實現(xiàn)了不同組件(不同頁面)的數(shù)據(jù)共享
//引入vuex
import Vue from 'vue';
import Vuex from 'vuex';
Vue.use(Vuex);
// 用Vuex實現(xiàn)數(shù)據(jù)的持久化
/* 1.state 在vuex中主要用于存儲數(shù)據(jù) */
var state={
num:1,
info:[]
}
// 2.mutation里面放的是方法,方法主要用于改變state里面的數(shù)據(jù)
var mutations={
Count(){
++state.num;
},
//傳值必須寫state
storeItemInfo(state,data){
state.info=data;
// state.list.push(data);
}
}
// 3.類似計算屬性,改變state里面的count數(shù)據(jù)的時候,會差發(fā)getters里面的方法,獲取新的值
var getters={
computedCount: (state) => {
return state.count*2;
}
}
// 3.vuex 實例化Vuex.Store
const store = new Vuex.Store({
state, /* 簡寫 */
mutations,
getters
})
//4.暴露store
export default store;
這就是實現(xiàn)該效果的全部代碼,用到了es6函數(shù),vuex,請求數(shù)據(jù)。反正我現(xiàn)在終于有點兒體會到了es6函數(shù)的好處了,希望也能幫到你們啊。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
vue循環(huán)中點擊選中再點擊取消(單選)的實現(xiàn)
這篇文章主要介紹了vue循環(huán)中點擊選中再點擊取消(單選)的實現(xiàn),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09
Vue監(jiān)聽數(shù)據(jù)渲染DOM完以后執(zhí)行某個函數(shù)詳解
今天小編就為大家分享一篇Vue監(jiān)聽數(shù)據(jù)渲染DOM完以后執(zhí)行某個函數(shù)詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09
vue3中el-table實現(xiàn)表格合計行的示例代碼
這篇文章主要介紹了vue3中el-table實現(xiàn)表格合計行,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2024-01-01

