全栈开发学习(Node+Vue+Mongodb)(十)——后台数据展示到移动端页面

本专题文章共十篇,已完结,后续有补充会实时更新。

1 后台数据录入

  • 录入后台数据的各种分类(手动)

  • 爬取官网的数据

    Chrome 里console中输入:

    $$('选择器') =》

    $$('选择器 ').map(el=>el.innerHTML) =》

    *.slice(5) * //跳过5条数据

  • 在数据库中引入所有模型 ,在server里安装:npm i require-all

    在db.js中引入

     require('require-all')(__dirname + '/../models') //引用了models里所有js
    
  • 在移动端接口文件下通过js的方式直接录入

    创建init接口

     router.get('/news/init', async (req, res) => {
        const parent = await Category.findOne({
          name: '新闻分类'
        })
        const cats = await Category.find().where({     
          parent: parent
        }).lean()  //获取分类,取json格式
      //爬取的数据粘贴在这里
        const newsTitles = ["凤求凰&“.................]
        
        //循环newsTitles 得到对象数组
        const newsList = newsTitles.map(title => {
      //随机取分类
          const randomCats = cats.slice(0).sort((a, b) => Math.random() - 0.5)
          return {
            categories: randomCats.slice(0, 2),  //对应的分类
            title: title
          }
        })
    
         await Article.deleteMany({})       //将数据库所有内容清空
         await Article.insertMany(newsList) //插入newsList数据
        res.send(newsList)
      })
    

    ps:注意,要批量向后台导入数据时要先在浏览器调用一下这个init接口,否则不会执行插入语句也就没有导入数据的效果。

2 数据接口

新建get接口,用于前端调用

router.get('/news/list',async(req,res)=>{
    const parent=await Category.findOne({
        name:'新闻分类'
    })
      /*聚合查询*/
    const cats = await Category.aggregate([
        { $match: { parent: parent._id } },  //过滤数据,条件查询上级分类
        {
          /*能够查询出每个分类底下的所有文章*/
          $lookup: {         //关联查询
            from: 'articles',  //从Article模型中查询
            localField: '_id', 
            foreignField: 'categories',  //外键
            as: 'newsList'  //命名为newsList
          }
        },
        {
            $addFields: {
              newsList: { $slice: ['$newsList', 5] }  //只取每个分类底下的5个文章数据
            }
          }
        ])
         /*新增热门分类,其中的文章从其他的分类中获取得到*/
        const subCats = cats.map(v => v._id)  //子分类是之前的那4个分类
        //在4个类别前加上“热门”分类
        cats.unshift({
          name: '热门',
          newsList: await Article.find().where({
            categories: { $in: subCats }
          }).populate('categories').limit(5).lean()
        })
        //获取热门分类里的文章的原分类
        cats.map(cat => {
          cat.newsList.map(news => {
            news.categoryName = (cat.name === '热门')   
              ? news.categories[0].name : cat.name
            return news
          })
          return cat
        })
        res.send(cats)
  })

3 数据展示

移动端数据展示的方法和之前后台管理界面的类似,此处不再赘述

  • 在web中安装axios并引入???/p>

    import axios from 'axios'
    Vue.prototype.$http =axios.create({
      baseURL:process.env.VUE_APP_API_URL || '/web/api'
    })
    
  • methods

     async fetchNewsCats(){
            const res =await this.$http.get('news/list')
            this.newsCats=res.data
          }
    

4 其他细节问题

  • swiper

    • 英雄板块告诉随元素内容多少变化

       <swiper ref="list"  :options="{autoHeight:true}" >
      
    • 导航高亮跟随swiper而变化

       <swiper ref="list" @slide-change="()=>active=$refs.list.swiper.realIndex">
      
  • 英雄技能点击跳转到对应描述

    <!-- skills -->
          <div class="skills bg-white mt-4">
               <div class="d-flex jc-around">
                    <img 
                         class="icon"
                         @click="currentSkillIndex=i"
                         :class="{active:currentSkillIndex===i}"
                         :src="item.icon" alt="" 
                         v-for="(item,i) in model.skills" :key="item.name"/>
                </div>
                    <div v-if="currentSkill">
                         <div class="d-flex pt-4 pb-2 ml-2">   
                            <h3 class="m-0">{{currentSkill.name}}</h3>
                                <span class="text-grey ml-4">
                              (冷却值:{{currentSkill.delay}} 消耗:{{currentSkill.cost}})
                                 </span>
                          </div>
                             <p class="ml-2">{{currentSkill.description}}</p>
                                <div class="border-bottom"></div>
                                   <p class="text-grey">小提示:{{currentSkill.tips}}</p>
                                </div>
                             </div>
    <!-- end of skills -->
    
    computed:{
             currentSkill(){
                 return this.model.skills[this.currentSkillIndex]
             }
         }
    
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,992评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,212评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,535评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,197评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,310评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,383评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,409评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,191评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,621评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,910评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,084评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,763评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,403评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,083评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,318评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,946评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,967评论 2 351

推荐阅读更多精彩内容