欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue仿今日頭條實例詳解

 更新時間:2018年02月06日 08:43:59   投稿:laozhang  
這篇文章主要介紹了Vue仿今日頭條實例詳解,并把相關代碼做了說明,對此有興趣的朋友參考下吧。

前言

vue也弄了一段時間了, 前段時間一直想用vue寫個移動端,加之年底也不是很忙,于是前幾天便著手開始弄了,到今天為止也算是勉強能看了

因為也是純粹的寫寫前端頁面,所以數(shù)據(jù)方面用的是mock.js,為了真實的模擬請求,可以直接在 Easy Mock 自己生成API
也可直接登陸我這項目的Easy Mock賬號密碼:

賬號: vue-toutiao
密碼: 123456

如果你想修改接口,請copy一份在修改

如果你想后臺接口也自己開發(fā)的話。可以閱讀我這篇博客 Vue + Node + Mongodb 開發(fā)一個完整博客流程

技術棧:

vue + webpack + vuex + axios

結構:

  • build: webpack配置
  • config: 項目配置參數(shù)
  • src
  • assets: 靜態(tài)資源文件,存放圖片啥的
  • components: 常用組件。例如 彈窗 等等。。。
  • directive: 常用指令封裝
  • router: 路由表
  • store: 狀態(tài)管理 vuex
  • styles: 樣式文件
  • utils: 常用工具類封裝
  • views: 視圖頁面
  • static: 靜態(tài)文件: 存放 favicon.ico 等等
  • 此項目用到了 DllPlugin 進行打包處理,所有啟動該項目時記得,先執(zhí)行一次該腳本命令生成配置

效果演示:

幾個常用的知識點

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)設置需要登陸
{ 
  path: '/system', 
  name: '系統(tǒng)設置', 
  meta: { 
    login: true
  },
  component: _import_('System/index')
}

router.beforeEach((to, from, next) => {
  if (to.meta.login) { //判斷前往的界面是否需要登陸
    if (store.state.user.user.name) { // 是否已經登陸
      next()
    }else{
      Vue.prototype.$alert('請先登錄!')
        .then( () => {
          store.state.user.isLogin = true
        })
    }
  }else{
    if (to.meta.page) store.state.app.pageLoading = true
    next() 
  }
  
})

3. 動畫切換

通過檢測設置在 Router上的animate屬性 來判斷它做什么樣的切換動畫

Router.prototype.animate = 0

// 獲取每個路由meta上面的slide 來判斷它做什么動畫
{ 
  path: '/system', 
  name: '系統(tǒng)設置', 
  meta: { 
    slide: 1 
  },
  component: _import_('System/index')
}


watch: {
  $route (to, from) {
    /*
    0: 不做動畫
    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. 視頻播放

因為在IOS上 無法隱藏video的controls ,所以我們可以隱藏video,通過繪制canvas來達到播放視頻的效果

5. icon采用的是 阿里巴巴矢量圖

6. mock.js

7. Easy Mock

代碼實例:https://github.com/cd-dongzi/vue-project/tree/master/vue-toutiao

相關文章

  • 利用vue3仿蘋果系統(tǒng)側邊消息提示效果實例

    利用vue3仿蘋果系統(tǒng)側邊消息提示效果實例

    這篇文章主要給大家介紹了關于如何利用vue3仿蘋果系統(tǒng)側邊消息提示效果的相關資料,文中通過實例代碼以及圖文介紹的非常詳細,對大家學習或者使用vue3具有一定的參考學習價值,需要的朋友可以參考下
    2021-12-12
  • vue利用全局導航守衛(wèi)作登錄后跳轉到未登錄前指定頁面的實例代碼

    vue利用全局導航守衛(wèi)作登錄后跳轉到未登錄前指定頁面的實例代碼

    這篇文章主要介紹了vue利用全局導航守衛(wèi)作登錄后跳轉到未登錄前指定頁面,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05
  • 詳解Vue的異步更新實現(xiàn)原理

    詳解Vue的異步更新實現(xiàn)原理

    這篇文章主要介紹了Vue的異步更新實現(xiàn)原理,幫助大家更好的理解和使用vue,感興趣的朋友可以了解下
    2020-12-12
  • vue搭建本地JSON靜態(tài)數(shù)據(jù)服務器全過程

    vue搭建本地JSON靜態(tài)數(shù)據(jù)服務器全過程

    這篇文章主要介紹了vue搭建本地JSON靜態(tài)數(shù)據(jù)服務器全過程,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • vue element upload實現(xiàn)圖片本地預覽

    vue element upload實現(xiàn)圖片本地預覽

    這篇文章主要為大家詳細介紹了vue element upload實現(xiàn)圖片本地預覽,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • Vue項目引發(fā)的「過濾器」使用教程

    Vue項目引發(fā)的「過濾器」使用教程

    這篇文章主要給大家介紹了關于Vue項目引發(fā)的「過濾器」使用的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者使用vue具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-03-03
  • vue中PC端地址跳轉移動端的操作方法

    vue中PC端地址跳轉移動端的操作方法

    最近小編接到一個項目pc端和移動端是兩個獨立的項目,兩個項目項目中的內容基本相同,鏈接組合的方式都有規(guī)律可循,接到的需求便是在移動端訪問pc端的URL連接時,重定向至移動端對應頁面,下面小編給大家分享實現(xiàn)過程,一起看看吧
    2021-11-11
  • 如何在基于vue-cli的項目自定義打包環(huán)境

    如何在基于vue-cli的項目自定義打包環(huán)境

    本篇文章主要介紹了在基于vue-cli的項目自定義打包環(huán)境,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • vue swipeCell滑動單元格(仿微信)的實現(xiàn)示例

    vue swipeCell滑動單元格(仿微信)的實現(xiàn)示例

    這篇文章主要介紹了vue swipeCell滑動單元格(仿微信)的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • Vue Element前端應用開發(fā)之界面語言國際化

    Vue Element前端應用開發(fā)之界面語言國際化

    我們開發(fā)的系統(tǒng),一般可以不用考慮語言國際化的問題,大多數(shù)系統(tǒng)一般是給本國人使用的,而且直接使用中文開發(fā)界面會更加迅速 一些,不過框架最好能夠支持國際化的處理,以便在需要的時候,可以花點時間來實現(xiàn)多語言切換的處理,使系統(tǒng)具有更廣泛的受眾用戶。
    2021-05-05

最新評論