新闻小程序5——新闻详情页面跳转逻辑实现

公共逻辑

假设已经获取到了数据,是存放在common.js中的,模拟这一动作,在common.js中添加代码

const news=[{
  article: {
  id: '1',
  title: 'miaomiao',
  poster: 'https://res.wx.qq.com/wxdoc/dist/assets/img/0.4cb08bb4.jpg',
  add_date: '2021-04-07',
  content: ' 程序员不想头秃 '
  }
}]

然后还需要添加自定义函数

//获取新闻列表
function getNewsList() {
  let list = [];
  for (var i = 0; i < news.length; i++) {
    let obj = {};
    obj.id = news[i].id;
    obj.poster = news[i].poster;
    obj.add_date = news[i].add_date;
    obj.title = news[i].title;
    list.push(obj);
  }
  return list; //返回新闻列表
}

//获取新闻内容
function getNewsDetail(newsID) {
  let msg = {
    code: '404', //没有对应的新闻
    news: {}
  };
  for (var i = 0; i < news.length; i++) {
    if (newsID == news[i].id) { //匹配新闻id编号
      msg.code = '200'; //成功
      msg.news = news[i]; //更新当前新闻内容
      break;
    }
  }
  return msg; //返回查找结果
}

/*
 * 对外暴露接口
 */
module.exports = {
  getNewsList: getNewsList,
  getNewsDetail: getNewsDetail
}

函数完成之后需要在所有的其他页面的js文件顶端加入引用

var common = require('../../utils/common.js') //引用公共JS文件

首页逻辑

展示新闻列表

在index的onload函数中添加获取和更新新闻的代码

  onLoad: function (options) {
    //获取新闻列表
    let list = common.getNewsList()
    //更新列表数据
    this.setData({newsList:list})
  },
点击跳转新闻详情

index.wxml文件中的新闻列表中的text添加代码使用gotodetail函数

<text bindtap='goToDetail' data-id='{{news.id}}'>⚫️{{news.title}}——{{news.add_date}}</text>

函数在index.js和detail.js中创建

Page({

  //自定义函数
  goToDetail:function(e){
    let id = e.currentTarget.dataset.id;
    wx.navigateTo({
      url: '../detail/detail?id='+id
    })
  },
  //.....

同时还需要在detail.js创建onload的函数

  onLoad: function (options) {
    let id = options.id
    let result = common.getNewsDetail(id)
    if(result.code=='200'){
      this.setData({article:result.news})
    }
  },

此时已经可以在首页点击列表跳转了
在这里插入图片描述

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

油泼西红柿

Wish U Thrive

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值