摘要:概念圖此文章參考網絡教程清單實現過程項目說明這個簡單小項目只提供一個小小小的骨架,需要向它身上具體加多少肉,需要大家考慮好功能和布局后進行完善。詳情請看下圖具體文件夾以及文件名稱可根據自己項目進行自擬。
概念圖 此文章參考網絡教程
https://www.jianshu.com/p/ec436222c608清單(實現過程) 項目說明
ps:這個簡單小項目只提供一個小小小的骨架,需要向“它”身上具體加多少“肉”,需要大家考慮好功能和布局后進行完善。
1.首先看下主頁效果:如下圖主頁分析:大體上分為上(header)、中(body或content)、下(footer)三部分,中間body部分是由若干個相同的li組成的“列表”,所以我們可將li定義為一個組件。
2.再來看下商品詳情頁:如下圖詳情頁分析:也分為上、中、下三部分。
配置目錄文件在src文件夾(也就是我們碼農主要工作區)下,創建assets文件夾(用來保存項目所需圖片)、components(存組件commonFooter.vue、DetailHeader.vue、homeHeader.vue、list.vue)、pages(存頁面goodsDetail.vue、home.vue)和main.js文件。詳情請看下圖:
ps: 1.具體文件夾以及文件名稱可根據自己項目進行“自擬”。 2.這里的每一個*.vue文件都是一個組件。
配置相關接口主頁商品信息及圖片, 是從服務器端返回的json數據,不可能所以商品都“寫死”。故這里需要模擬后臺建立了一個數據文件。在根目錄下建立一個goods.json文件用來放“偽數據”,如下圖:
注意json里不能帶有注釋和其他文字,不然會項目跑不起來,出錯
{ "goods": [ { "price": "69.9", "title": "德芙", "img": "http://m.360buyimg.com/babel/s211x211_jfs/t3688/270/776223567/128582/fa074fb3/58170f6dN6b9a12bf.jpg!q50.jpg.webp" }, { "price": "63", "title": "費列羅", "img": "http://m.360buyimg.com/babel/s211x211_jfs/t613/100/1264998035/221234/1a29d51f/54c34525Nb4f6581c.jpg!q50.jpg.webp"}, { "price": "29.9", "title": "大米", "img": "http://m.360buyimg.com/babel/s211x211_jfs/t1258/40/17387560/108696/aced445f/54e011deN3ae867ae.jpg!q50.jpg.webp"}, { "price": "54.9", "title": "安慕希", "img": "http://m.360buyimg.com/babel/s211x211_jfs/t2734/15/680373407/215934/3abaa748/572057daNc09b5da7.jpg!q50.jpg.webp"}, { "price": "58", "title": "金典", "img": "http://m.360buyimg.com/babel/s211x211_jfs/t2482/145/1424008556/91991/d62f5454/569f47a2N3f763060.jpg!q50.jpg.webp"}, { "price": "60", "title": "味可滋", "img": "http://m.360buyimg.com/babel/s211x211_jfs/t2368/3/874563950/70786/7b5e8edd/563074c8N4d535db4.jpg!q50.jpg.webp" }, { "price": "248.00", "title": "瀘州老窖", "img": "http://m.360buyimg.com/babel/s211x211_jfs/t283/166/1424018055/189580/7c0792b7/543b4958N05fa2feb.jpg!q50.jpg.webp"}, { "price": "328.8", "title": "劍南春", "img": "http://m.360buyimg.com/babel/s350x350_g15/M05/1A/0A/rBEhWlNeLAwIAAAAAAHyok3PZY0AAMl8gO8My0AAfK6307.jpg!q50.jpg.webp"}, { "price": "49.00", "title": "藍莓", "img": "http://m.360buyimg.com/babel/s211x211_jfs/t2332/148/2952098628/94387/e64654e2/56f8d76aNb088c2ab.jpg!q50.jpg.webp" }, { "price": "68", "title": "芒果", "img": "http://m.360buyimg.com/n0/jfs/t3709/334/1378702984/206759/5c100ab5/58253588Naaa05c5c.jpg!q70.jpg"} ] }
使用node中的express,
安裝express和axios
在main.js里配置axios到原型鏈中
注意標記的那兩行
import Vue from "vue" import App from "./App" import router from "./router" import axios from "axios" //注意這行 Vue.prototype.$http = axios; //注意這行 Vue.config.productionTip = false new Vue({ el: "#app", router, components: { App }, template: "" })
在build>>webpack.dev.conf.js配置express并設置路由規則
如圖:
代碼如下:
"use strict" const utils = require("./utils") const webpack = require("webpack") const config = require("../config") const merge = require("webpack-merge") const baseWebpackConfig = require("./webpack.base.conf") const HtmlWebpackPlugin = require("html-webpack-plugin") const FriendlyErrorsPlugin = require("friendly-errors-webpack-plugin") const portfinder = require("portfinder") /* datura_lj 增加express 20171126 */ const express = require("express") const app = express() var appData = require("../goods.json")/*加載本地數據文件*/ var goods = appData.goods var apiRoutes = express.Router() app.use("/api", apiRoutes) /* 增加express end */ const devWebpackConfig = merge(baseWebpackConfig, { module: { rules: utils.styleLoaders({ sourceMap: config.dev.cssSourceMap, usePostCSS: true }) }, // cheap-module-eval-source-map is faster for development devtool: config.dev.devtool, // these devServer options should be customized in /config/index.js devServer: { clientLogLevel: "warning", historyApiFallback: true, hot: true, compress: true, host: process.env.HOST || config.dev.host, port: process.env.PORT || config.dev.port, open: config.dev.autoOpenBrowser, overlay: config.dev.errorOverlay ? { warnings: false, errors: true, } : false, publicPath: config.dev.assetsPublicPath, proxy: config.dev.proxyTable, quiet: true, // necessary for FriendlyErrorsPlugin watchOptions: { poll: config.dev.poll, }, /* datura_lj 增加express 20171126 */ before(app) { app.get("/api/goods", (req, res) => { res.json({ code: 0, data: goods }) }) } /* datura_lj 增加路由規則 end */ }, plugins: [ new webpack.DefinePlugin({ "process.env": require("../config/dev.env") }), new webpack.HotModuleReplacementPlugin(), new webpack.NamedModulesPlugin(), // HMR shows correct file names in console on update. new webpack.NoEmitOnErrorsPlugin(), // https://github.com/ampedandwired/html-webpack-plugin new HtmlWebpackPlugin({ filename: "index.html", template: "index.html", inject: true }), ] }) module.exports = new Promise((resolve, reject) => { portfinder.basePort = process.env.PORT || config.dev.port portfinder.getPort((err, port) => { if (err) { reject(err) } else { // publish the new Port, necessary for e2e tests process.env.PORT = port // add port to devServer config devWebpackConfig.devServer.port = port // Add FriendlyErrorsPlugin devWebpackConfig.plugins.push(new FriendlyErrorsPlugin({ compilationSuccessInfo: { messages: [`Your application is running here: http://${config.dev.host}:${port}`], }, onErrors: config.dev.notifyOnErrors ? utils.createNotifierCallback() : undefined })) resolve(devWebpackConfig) } }) })
npm run dev 之后,測試是否該數據可用,在瀏覽器地址欄中輸入:http://localhost:8080/api/goods ,在瀏覽器中展示出如下圖數據,代碼數據數取成功:
配置config/index.js:解決跨域問題
在proxTable對象里寫:
proxyTable: { "/api": { target: "http://127.0.0.1:8080/api", changeOrigin: true, pathRewrite: { "^/api": "/" //寫"/api"就等于寫"http://127.0.0.1:8080/api" //到時候寫"/api/goods"就等于寫"http://127.0.0.1:8080/api/goods" } } }
原來參考教程有些地方需要修改:
home.vue里的獲取數據要改成這樣才對:
2.修改list.vue里的價格顯示那行代碼
3.在home.vue里修改組件 : v-for="(item, index) in items" :key="index" 這樣就可以運行了
期待擴寫功能:實現點擊商品列表的某一項(商品列表為請求數據循環輸出),傳參到詳情頁,詳情頁根據傳過來的參數去請求數據回來填充到頁面.
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/95764.html
摘要:并總結經典面試題集各種算法和插件前端視頻源碼資源于一身的文檔,優化項目,在瀏覽器端的層面上提升速度,幫助初中級前端工程師快速搭建項目。 本文是關注微信小程序的開發和面試問題,由基礎到困難循序漸進,適合面試和開發小程序。并總結vue React html css js 經典面試題 集各種算法和插件、前端視頻源碼資源于一身的文檔,優化項目,在瀏覽器端的層面上提升速度,幫助初中級前端工程師快...
摘要:并總結經典面試題集各種算法和插件前端視頻源碼資源于一身的文檔,優化項目,在瀏覽器端的層面上提升速度,幫助初中級前端工程師快速搭建項目。 本文是關注微信小程序的開發和面試問題,由基礎到困難循序漸進,適合面試和開發小程序。并總結vue React html css js 經典面試題 集各種算法和插件、前端視頻源碼資源于一身的文檔,優化項目,在瀏覽器端的層面上提升速度,幫助初中級前端工程師快...
摘要:并總結經典面試題集各種算法和插件前端視頻源碼資源于一身的文檔,優化項目,在瀏覽器端的層面上提升速度,幫助初中級前端工程師快速搭建項目。 本文是關注微信小程序的開發和面試問題,由基礎到困難循序漸進,適合面試和開發小程序。并總結vue React html css js 經典面試題 集各種算法和插件、前端視頻源碼資源于一身的文檔,優化項目,在瀏覽器端的層面上提升速度,幫助初中級前端工程師快...
閱讀 1972·2021-11-23 10:03
閱讀 4130·2021-11-22 09:34
閱讀 2466·2021-10-08 10:05
閱讀 2247·2019-08-30 15:53
閱讀 1686·2019-08-30 13:56
閱讀 1149·2019-08-29 16:52
閱讀 1102·2019-08-26 13:31
閱讀 3346·2019-08-26 11:45