Vue仿今日頭條實(shí)例詳解
前言
vue也弄了一段時(shí)間了, 前段時(shí)間一直想用vue寫個(gè)移動(dòng)端,加之年底也不是很忙,于是前幾天便著手開始弄了,到今天為止也算是勉強(qiáng)能看了
因?yàn)橐彩羌兇獾膶憣懬岸隧撁?所以數(shù)據(jù)方面用的是mock.js,為了真實(shí)的模擬請(qǐng)求,可以直接在 Easy Mock 自己生成API
也可直接登陸我這項(xiàng)目的Easy Mock賬號(hào)密碼:
賬號(hào): vue-toutiao
密碼: 123456
如果你想修改接口,請(qǐng)copy一份在修改
如果你想后臺(tái)接口也自己開發(fā)的話??梢蚤喿x我這篇博客 Vue + Node + Mongodb 開發(fā)一個(gè)完整博客流程
技術(shù)棧:
vue + webpack + vuex + axios
結(jié)構(gòu):
- build: webpack配置
- config: 項(xiàng)目配置參數(shù)
- src
- assets: 靜態(tài)資源文件,存放圖片啥的
- components: 常用組件。例如 彈窗 等等。。。
- directive: 常用指令封裝
- router: 路由表
- store: 狀態(tài)管理 vuex
- styles: 樣式文件
- utils: 常用工具類封裝
- views: 視圖頁面
- static: 靜態(tài)文件: 存放 favicon.ico 等等
- 此項(xiàng)目用到了 DllPlugin 進(jìn)行打包處理,所有啟動(dòng)該項(xiàng)目時(shí)記得,先執(zhí)行一次該腳本命令生成配置
效果演示:





幾個(gè)常用的知識(shí)點(diǎn)
1. 路由懶加載
{
path: '/development',
name: 'development',
component: (resolve) => {
require(['../views/development.vue'], resolve)
}
}
或
const _import_ = file => () => import('views/' + file + '.vue')
{
path: '/development',
name: 'development',
component: _import_('development')
}
2. 登陸攔截
通過路由的 beforeEach 鉤子函數(shù)來判斷是否需要登陸
// 如:系統(tǒng)設(shè)置需要登陸
{
path: '/system',
name: '系統(tǒng)設(shè)置',
meta: {
login: true
},
component: _import_('System/index')
}
router.beforeEach((to, from, next) => {
if (to.meta.login) { //判斷前往的界面是否需要登陸
if (store.state.user.user.name) { // 是否已經(jīng)登陸
next()
}else{
Vue.prototype.$alert('請(qǐng)先登錄!')
.then( () => {
store.state.user.isLogin = true
})
}
}else{
if (to.meta.page) store.state.app.pageLoading = true
next()
}
})
3. 動(dòng)畫切換
通過檢測(cè)設(shè)置在 Router上的animate屬性 來判斷它做什么樣的切換動(dòng)畫
Router.prototype.animate = 0
// 獲取每個(gè)路由meta上面的slide 來判斷它做什么動(dòng)畫
{
path: '/system',
name: '系統(tǒng)設(shè)置',
meta: {
slide: 1
},
component: _import_('System/index')
}
watch: {
$route (to, from) {
/*
0: 不做動(dòng)畫
1: 左切換
2: 右切換
3: 上切換
4: 下切換
...
*/
let animate = this.$router.animate || to.meta.slide
if (!animate) {
this.animate = ''
}else{
this.animate = animate === 1 ? 'slide-left' :
animate === 2 ? 'slide-right' :
animate === 3 ? 'slide-top' :
animate === 4 ? 'slide-bottom' : ''
}
this.$router.animate = 0
}
}
4. 視頻播放
因?yàn)樵贗OS上 無法隱藏video的controls ,所以我們可以隱藏video,通過繪制canvas來達(dá)到播放視頻的效果
5. icon采用的是 阿里巴巴矢量圖
6. mock.js
7. Easy Mock
代碼實(shí)例:https://github.com/cd-dongzi/vue-project/tree/master/vue-toutiao
相關(guān)文章
vue2結(jié)合element-ui的gantt圖實(shí)現(xiàn)可拖拽甘特圖
因?yàn)楣ぷ髦幸玫礁侍貓D,所以我在網(wǎng)上搜索可以用的甘特圖,搜索了好多,但是網(wǎng)上搜到大多數(shù)都很雞肋,不能直接使用,下面這篇文章主要給大家介紹了關(guān)于vue2結(jié)合element-ui的gantt圖實(shí)現(xiàn)可拖拽甘特圖的相關(guān)資料,需要的朋友可以參考下2022-11-11
vue-treeselect無法點(diǎn)擊問題(點(diǎn)擊無法出現(xiàn)拉下菜單)
這篇文章主要介紹了vue-treeselect無法點(diǎn)擊問題(點(diǎn)擊無法出現(xiàn)拉下菜單),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
Element-UI結(jié)合遞歸組件實(shí)現(xiàn)后臺(tái)管理系統(tǒng)左側(cè)菜單
在Vue.js中使用遞歸組件可以方便地構(gòu)建多層級(jí)的菜單結(jié)構(gòu),遞歸組件適用于處理具有嵌套關(guān)系的數(shù)據(jù),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-09-09
詳解element上傳組件before-remove鉤子問題解決
這篇文章主要介紹了詳解element上傳組件before-remove鉤子問題解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04

