您现在的位置是:主页 > news > 网站建设需注意的/时事新闻

网站建设需注意的/时事新闻

admin2025/5/26 5:06:17news

简介网站建设需注意的,时事新闻,贵州能源网站 中企动力建设,做直播网站有哪些详情 - 数据渲染 本文配套视频地址:https://v.qq.com/x/page/x055550lrvd.html 开始前请把 ch4-2 分支中的 code/ 目录导入微信开发工具 这一节中,我们开始详情的接口调用、数据加载和视图渲染过程。 Step 1. 引入公用的一些工具库,修改 deta…

网站建设需注意的,时事新闻,贵州能源网站 中企动力建设,做直播网站有哪些详情 - 数据渲染 本文配套视频地址:https://v.qq.com/x/page/x055550lrvd.html 开始前请把 ch4-2 分支中的 code/ 目录导入微信开发工具 这一节中,我们开始详情的接口调用、数据加载和视图渲染过程。 Step 1. 引入公用的一些工具库,修改 deta…

§ 详情 - 数据渲染

本文配套视频地址:
https://v.qq.com/x/page/x055550lrvd.html


开始前请把 ch4-2 分支中的 code/ 目录导入微信开发工具
这一节中,我们开始详情的接口调用、数据加载和视图渲染过程。


Step 1. 引入公用的一些工具库,修改 detail.js

'use strict';import util from '../../utils/index';
import config from '../../utils/config';// WxParse HtmlFormater 用来解析 content 文本为小程序视图
import WxParse from '../../lib/wxParse/wxParse';
// 把 html 转为化标准安全的格式
import HtmlFormater from '../../lib/htmlFormater';let app = getApp();
Page({});


Step 2. 修改 detail.js 在页面初始化时候,请求接口,加载详情数据

Page({onLoad (option) {/** 函数 `onLoad` 会在页面初始化时候加载运行,其内部的 `option` 是路由跳转过来后的参数对象。* 我们从 `option` 中解析出文章参数 `contendId`,然后通过调用 `util` 中封装好的 `request` 函数来获取 `mock` 数据。 */ let id = option.contentId || 0;this.init(id);},init (contentId) {if (contentId) {this.requestDetail(contentId).then(data => {util.log(data)})}},requestDetail(contentId){return util.request({url: 'detail',mock: true,data: {source: 1}}).then(res => {return res})}
})


运行之后,我们查看下控制台输出的数据,是不是很清晰!

0cd8e9b8cde49fdde4a154328daa5171

Step 3. 接着,把页面头部数据渲染出来

修改 requestDetail 函数,并增加日期格式化的方法,达到我们想要的效果,然后重新返回数据

Page({// 此处省略部分代码requestDetail(contentId){return util.request({url: 'detail',mock: true,data: {source: 1}}).then(res => {let formateUpdateTime = this.formateTime(res.data.lastUpdateTime)// 格式化后的时间res.data.formateUpdateTime = formateUpdateTimereturn res.data})},formateTime (timeStr = '') {let year = timeStr.slice(0, 4),month = timeStr.slice(5, 7),day = timeStr.slice(8, 10);return `${year}/${month}/${day}`;}
})


现在我们已经获取到了后端返回的数据,并且已经把部分数据标准处理过。下一步,我们把返回的数据同步到 Model 层中(也就是 data 对象中)
我们增加 configPageData 函数,用它来处理数据同步到 data的逻辑:

Page({data: {detailData: {}},init (contentId) {if(contentId) {this.requestDetail(contentId).then(data => {this.configPageData(data)})}},configPageData(data){if (data) {// 同步数据到 Model 层,Model 层数据发生变化的话,视图层会自动渲染this.setData({detailData: data});//设置标题let title = this.data.detailData.title || config.defaultBarTitlewx.setNavigationBarTitle({title: title})}}
})


因为页面的标题是随着文章变化的,所以需要我们动态设置,这里我们调用了小程序自带的方法来设计

wx.setNavigationBarTitle({title: '标题'
})


修改视图 detail.wxml 的头部 class="info" 内容:

<view class="info"><view class="info-title">{{ detailData.title }}</view><view class="info-desc cf"><text class="info-desc-author fl">{{ detailData.author }}</text><text class="info-desc-date fr">{{ detailData.formateUpdateTime}}</text></view><view class="info-line under-line"></view>
</view>


Step 4. 调用 parse 解析接口返回的 content 字段(文本内容)

当详情数据返回后,我们已经对部分数据进行了过滤处理,现在修改 detail.js 中的 init 函数,增加对文章正文的处理:

    articleRevert () {// this.data.detailData 是之前我们通过 setData 设置的响应数据let htmlContent = this.data.detailData && this.data.detailData.content;WxParse.wxParse('article', 'html', htmlContent, this, 0);},init (contentId) {if (contentId) {this.requestDetail(contentId).then(data => {this.configPageData(data)})//调用wxparse.then(()=>{this.articleRevert()})}},


注意看上面的 articleRevert 函数,变量 htmlContent 指向文章的正文数据,当其传入到组件 WxParse 后,同时带入了 5 个参数

WxParse.wxParse('article', 'html', htmlContent, this, 0);


第一个参数 article 很重要,在 WxParse 中,我们传入了当前对象 this,当变量 htmlContent 解析之后,会把解析后的数据赋值给当前对象,并命名为 article

16a05638ed4562c1c4b7e0e08cee3063

所以当文章数据解析后,当前环境上下文中已经存在了数据 article,可以直接在 detail.wxml 中引用:

this.data.article


修改 detail.wxml,引用我们的文章正文数据:

<!-- 先引入解析模板  -->
<import src="../../lib/wxParse/wxParse.wxml"/><!-- 修改文章正文节点  -->
<view class="content"><template is="wxParse" data="{{wxParseData:article.nodes}}"/>
</view>


再看下页面效果,文章已经正常的显示了,但我们还需要优化下样式,比如增加一些行高、文字间距、字体大小颜色、图片居中等。修改样式文件 detail.wxss增加 以下样式

.wrapper .content {padding: 0 36rpx;padding-bottom: 40rpx;line-height: 56rpx;color: #333;font-size: 36rpx;overflow: hidden;word-wrap: break-word
}.wrapper .content .langs_cn,.wrapper .content .para.translate {font-size: 32rpx;color: #666
}.wrapper .content .langs_cn,.wrapper .content .langs_en,.wrapper .content .para,.wrapper .content .wxParse-p {margin: 44rpx 0
}.wrapper .content image {max-width: 100%;vertical-align: top
}.wrapper .content .tip {color: #999;font-size: 28rpx;text-align: center;height: 28rpx;line-height: 28rpx
}.wrapper .content .tip-icon {vertical-align: top;margin-right: 8rpx;width: 26rpx;height: 26rpx;border: 1px solid #999;border-radius: 6rpx;box-sizing: border-box
}.wrapper .content .tip-icon.selected {border: none;background: url(https://n1image.hjfile.cn/mh/2017/06/12/20703f295b7b3ee4f5fe077c4e464283.png) 0 0 no-repeat;background-size: contain
}

iKcamp官网:http://www.ikcamp.com

访问官网更快阅读全部免费分享课程:《iKcamp出品|全网最新|微信小程序|基于最新版1.0开发者工具之初中级培训教程分享》。
包含:文章、视频、源代码

076d086e1d56bd0fb1f51c2abd0b8c08

iKcamp原创新书《移动Web前端高效开发实战》已在亚马逊、京东、当当开售。

【11月11号】上海iKcamp最新活动

e25a9cc8e3c0ff85ce16229e2e4b799c

报名地址:http://www.huodongxing.com/event/5409924174200

“天天练口语”小程序总榜排名第四、教育类排名第一的研发团队,面对面沟通交流。

转载于:https://www.cnblogs.com/ikcamp/p/7766316.html