亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

教你使用vue-cli快速構建的小說閱讀器

2019-11-19 11:35:28
字體:
來源:轉載
供稿:網友

項目介紹

主要頁面

1、首頁home.vue分類展示書籍,幻燈片展示熱門推薦

2、搜索search.vue,上拉加載更多

3、書籍詳情book.vue加入書架、立即閱讀,展示評論,同類書籍推薦

4、書籍內容read.vue,獲取目錄,存儲翻閱的章節位置,

5、書架bookrack.vue,獲取加入書架的書單

技術棧

vue、vue-cli、axios、vue-router、vuex、localStorege

  • 入口頁面app.vue

分成底部導航 跟 主視圖容器 router-view

首頁tabbar/Home

  • 包含: components/sub/item 和 components/sub/search 、components/sub/header
  • 結構: banner切換 與 搜索 和 小說分類樓層

小說樓層單獨定義了組件 components/sub/item , home循環樓層分類名稱,并將樓層分類id傳給item組件 :booklistId='{id:item._id}' , item組件用 props: ["booklistId"] 接收分類id, 并根據分類id獲取對應的數據

item.vue

mouted: this.getlist(this.booklistId.id);methods: getlist(id) { //每個分類id下對應的數據 子組件接收父組件傳過來的id 獲取對應的數據  bootd(id).then(res => {  var arrdata = res.data.data;  arrdata.map(item => {   this.booklist.push(item.book);  });  }); }

小說詳情頁components/book/Book.vue

  • 包含: components/sub/yuedu 、mulu、pinglun、
  • 結構: 小說概況與簡介,是否加入書架或者繼續閱讀 ,目錄、評論、同類書籍推薦

加入書架/立即閱讀(yuedu.vue)組件

book.vue

computed: {  ...mapState(['calbook','shuajiabook']) //書籍信息 書架數據[]  },  methods:{  addbook(){   this.flag=!this.flag   var book= this.calbook; // calbook 是store里存儲的書籍信息【 SHEFLBOOK 】   var carbook = JSON.parse(window.localStorage.getItem('book') || '{}')   if(!this.flag){ //加入書架    carbook[book._id] = {     cover: book.cover,     flag:!this.flag,     title: book.title,     lastChapter:book.lastChapter,     id: book._id,     author:book.author,     chapterIndexCache: 0,     bookSource: 0,     pageIndexCache: 0,    }    this.setbook(false)    window.localStorage.setItem('book', JSON.stringify(carbook))   }else{    delete carbook[book._id]    this.setbook(true) //設置的布爾值    window.localStorage.setItem('book', JSON.stringify(carbook))   }  } }

立即閱讀時進入小說章節 `this.$router.push({name:'read',params:{id:this.booklinks}})`

目錄組件 components/sub/mulu.vue

點擊目錄時,路由跳轉進入 read.vue 頁面(小說詳細章節),并且將默認目錄顯示出來,書籍id通過路由傳給 mulu.vue

book.vue

<router-link :to="{name:'read',params:{id:this.books._id,showMulu:true}}" class="mulu" tag="p">

read.vue包含mulu組件,默認目錄隱藏,通過路由傳參決定是否顯示目錄

<mulu :id="id" @readShow='readshows' v-show="showMulu" @closeLayer='backGo()'></mulu> // 控制目錄顯示狀態 created() {  this.getBook = JSON.parse(window.localStorage.getItem("SHEFLBOOK")); // book/book.vue 存儲的書籍信息  this.getbookhy(this.getBook._id); // 獲取小說id所對應的源   if(this.$route.params.showMulu){ //從book.vue傳過來的參數   this.showMulu = true  } },// 子組件mulu.vue發送過來的事件,點擊時跳轉到對應的章節內容 readshows(index){  this.showMulu = false  this.iss = index  this.getBookindex()  this.getcontent(this.booklinkss[this.iss]); //根據booklinkss顯示目錄章節  this.$refs.dvtop.scrollTop = 0; },

mulu.vue

<li v-for="item in list" :key="item.id" @click='getMulu((item.order)-1)'>{{item.title}} <em style="color:red">{{item.isVip?'vip':null}}</em></li>  getMulu(i){   this.$emit('readShow',i) //將點擊的章節傳給父組件 read.vue  }

pinglun.vue

評論組件(pinglun.vue),獲取路由中的參數書籍id,在item.vue中 <router-link tag='li' :to="{name:'book',params:{id:item._id}}"> 路由跳轉到詳情,并將書籍id傳給書籍詳情

created() { this.loadMore(); }, methods: { loadMore() {  bookpl(this.$route.params.id, this.limit).then(res => { // 獲取的item組件的路由參數 書籍id  if (res.status === 200) {   this.pinglun = res.data.reviews;   this.limit += 5;  }  });  this.loading = false; } }

小說章節詳情components/read/read.vue

  • 包含: components/sub/mulu 、
  • 結構:上一章下一章,目錄,章節內容

獲取localstorege的書籍信息SHEFLBOOK中的(id),[book.vue存儲了localstorege], 根據小說id獲取 【源--目錄--內容】 ,點擊目錄進入章節詳情,將點擊的章節存入local,記住每次點擊的章節位置,供后續閱讀

read.vue

//獲取小說資源 每本小說有多個資源 根據小說id獲取小說的來源  getbookhy(id){  bookhy(id).then(res=>{   this.bookhylist = res.data;   this.getmulu(this.bookhylist[0]._id);  // 根據源 獲取目錄數據 默認第一個源  })  }, getmulu(id){  this.booklinkss = []; //第N章內容  this.booktitle = []; //第N章標題 push后數據疊加 現將數組數據清空  var bookindexs = JSON.parse( window.localStorage.getItem("bookindex") || "{}" ); //章節位置  bookmulu(id).then(res=>{  if(res.status==200){    res.data.chapters.forEach( item => {   // 內容是根據link來獲取的 將link發給服務器,由于// / & # 服務器是無法識別的 所以需要對link轉碼 最后服務器返回內容     this.booklinkss.push(encodeURIComponent(item.link))    this.booktitle.push(item.title)   });  }  this.iss = bookindexs && bookindexs[this.getBook._id] ? bookindexs[this.getBook._id].bookindex : this.iss;  this.getcontent(this.booklinkss[this.iss]); // 根據目錄 獲取內容   }) },  // 獲取內容  getcontent(link){   var content = []   bookcontent(link).then(res => {    if(res.status == 200){    var datas = res.data.chapter;    content.push({     cpContent:datas.isVip?["vip章節,請購買VIP"]:(datas.cpContent ? datas.cpContent.split("/n") : datas.body.split("/n")),     title:datas.title    })    this.con = content[0]    }   })  },

小說搜索頁components/read/search.vue 調用MUI的 mt-loadmore 功能,上拉加載更多,

//獲取搜索的書籍 getList() {  booksearch(this.keyword).then(res => {  if (res.data.ok) {   this.searchList = res.data.books.slice(0, 15); //默認展示前15條數據  }  }); },  // 上拉加載 loadBottom() {  this.allLoaded = true; //上滑時出現加載文字  booksearch(this.keyword).then(res=>{   if(this.searchList.length==res.data.books.length){   this.allLoaded = false   }else{   this.searchList = res.data.books.splice(0,this.count*15+15) //每次拉動時在現有基礎上加15條 cout++   this.count++   this.allLoaded = false    }  }) },

項目截圖

倉庫代碼

https://github.com/msisliao/v...

總結

以上所述是小編給大家介紹的使用vue-cli快速構建的小說閱讀器,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产亚洲综合久久| 欧美激情一区二区三区高清视频| 性欧美xxxx视频在线观看| 久久久久久久一区二区| 亚洲va欧美va国产综合久久| 精品伊人久久97| 69av在线视频| 国产在线精品播放| 亚洲精品资源美女情侣酒店| 亚洲视频视频在线| 亚洲美女又黄又爽在线观看| 欧美精品在线免费| 中文字幕欧美精品日韩中文字幕| 色av中文字幕一区| 亚洲视屏在线播放| 亚洲欧美日韩中文视频| 亚洲精品suv精品一区二区| 国产精品影院在线观看| 成人免费在线视频网站| 一本色道久久综合狠狠躁篇的优点| 亚洲综合av影视| 国产精品免费看久久久香蕉| 欧美日韩亚洲高清| 亚洲天堂久久av| 正在播放欧美视频| 欧美日韩激情小视频| 精品在线欧美视频| 欧美成人合集magnet| 久久国产精品网站| 欧美激情精品久久久久久黑人| 国产一区二区三区精品久久久| 亚洲自拍欧美色图| 最新国产成人av网站网址麻豆| 色婷婷亚洲mv天堂mv在影片| 久久亚洲综合国产精品99麻豆精品福利| 欧美日韩亚洲精品一区二区三区| 国产www精品| 中文字幕精品www乱入免费视频| 国产精品亚洲欧美导航| www.久久色.com| 日韩欧美极品在线观看| 亚洲一级免费视频| 91免费欧美精品| 国产亚洲欧洲高清一区| 日韩欧美在线免费| 久久久久久尹人网香蕉| 色av中文字幕一区| 久久全球大尺度高清视频| 中文字幕av一区| 中文字幕在线观看日韩| 欧美极品少妇全裸体| 亚洲国产美女久久久久| 久久综合伊人77777蜜臀| 日韩精品视频免费专区在线播放| 最近2019年日本中文免费字幕| 欧美丝袜一区二区三区| 91久久国产精品| 91在线高清视频| 欧美成人在线免费| 久久99热精品这里久久精品| 日韩欧美成人网| 欧美老女人性视频| 亚洲一区国产精品| 国产成人精品久久二区二区| 日本精品视频网站| 夜色77av精品影院| 性色av香蕉一区二区| 日韩欧美成人精品| 秋霞午夜一区二区| 欧美激情视频三区| 欧美精品一区二区免费| 久久久www成人免费精品张筱雨| 国产精品成人久久久久| 久久免费高清视频| 国产精品电影观看| 国产成人一区二区在线| 久久国产视频网站| 欧美黑人巨大精品一区二区| 中文字幕久久精品| 亚洲一区中文字幕| 九九精品在线播放| 91网在线免费观看| 久久视频中文字幕| 国产精品一区二区av影院萌芽| 国产精品日韩在线观看| 亚洲伦理中文字幕| 亚洲日本欧美中文幕| 亚洲bt欧美bt日本bt| 久久久精品日本| 在线不卡国产精品| 欧美日韩国产中文精品字幕自在自线| 欧美有码在线视频| 久久精品国产96久久久香蕉| 国产精品免费视频久久久| 成人伊人精品色xxxx视频| www欧美xxxx| 亚洲日本成人网| 欧美最顶级丰满的aⅴ艳星| 久久久av亚洲男天堂| 热re99久久精品国产66热| 亚洲jizzjizz日本少妇| 日本高清不卡的在线| 亚洲最新av在线网站| 亚洲自拍在线观看| 97精品一区二区三区| 成人久久久久久久| 91亚洲午夜在线| 91在线精品视频| 色黄久久久久久| 欧美天天综合色影久久精品| 97视频在线观看视频免费视频| 欧美一级免费视频| 亚洲毛片在线免费观看| 中文字幕精品视频| 亚洲第一中文字幕| 久久人人97超碰精品888| 国产精品久久久久久久久影视| 91久久综合亚洲鲁鲁五月天| 亚洲欧美另类在线观看| 成人福利在线观看| 国产成+人+综合+亚洲欧洲| 成人网在线视频| 国产精品久久久久久久久久久久久久| 精品久久久精品| 欧美精品亚州精品| 中文字幕视频一区二区在线有码| 国产va免费精品高清在线观看| 日韩在线视频线视频免费网站| 亚洲人成自拍网站| 欧美性少妇18aaaa视频| 国内偷自视频区视频综合| 中文日韩在线视频| 另类天堂视频在线观看| 欧美日韩免费区域视频在线观看| 国产有码在线一区二区视频| 欧美在线观看视频| 最近2019免费中文字幕视频三| 国产亚洲一级高清| 久久av在线播放| 亚洲福利视频久久| 岛国视频午夜一区免费在线观看| 国产一区二区黄| 亚洲自拍小视频免费观看| 欧美中文字幕视频在线观看| 日韩暖暖在线视频| 在线观看欧美视频| 亚洲xxxx视频| 亚洲精品美女久久久久| 92版电视剧仙鹤神针在线观看| 日韩电影免费观看中文字幕| 91亚洲精品久久久久久久久久久久| 91成人免费观看网站| 国产97色在线| 欧美亚洲一区在线| 亚洲国产欧美一区| 欧美另类极品videosbest最新版本| 国产精品视频免费在线观看| 91九色单男在线观看| 中文字幕日韩av电影| 国产a级全部精品| 国内精品400部情侣激情| 欧美日韩亚洲系列| 成人免费黄色网| 亚洲专区中文字幕|