微信应用号入门实践之 cnode 社区版
首先感谢 cnode 社区提供的 api ,本次实现了简单的 cnode 社区应用号制作。
实现了数据的读取、展示,
实现了简单的布局,
实现了下一页功能。
下面就说说我做这个的过程,不足之处,请多多指教,只愿为进步。
首先,在官网下载工具,下载地址 我的是选择 mac 版本 0.9.092300 。
然后跟着官方的简版教程 创建一个项目。
默认的项目里已经没有关于 tabBar 的配置信息,所以为了学习,我把这个配置进行了修改。
首先关于配置的说明同样来自于官方
注意:官方的代码有些字段是不一样的,小心被坑。
{
"pages":[
"pages/index/index",
"pages/logs/logs"
],
"window":{
"backgroundTextStyle":"light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "WeChat",
"navigationBarTextStyle":"black"
},
"tabBar":{
"list": [{
"pagePath": "pages/index/index",
"text": "首页"
}, {
"pagePath": "pages/logs/logs",
"text": "日志"
}]
}
}
增加了 tabBar, 查看调试
"tabBar":{
"color":"#272636",
"selectedColor":"#80bd01",
"backgroundColor":"#fff",
"borderStyle":"white",
"list":[{
"pagePath":"pages/index/index",
"text":"首页",
"iconPath":"images/tabBar/my.png",
"selectedIconPath":"images/tabBar/my_hl.png"
},{
"pagePath":"pages/index/index",
"text":"我的",
"iconPath":"images/tabBar/list.png",
"selectedIconPath":"images/tabBar/list_hl.png"
}]
}
效果如图
"window":{
"backgroundTextStyle":"black",
"backgroundColor":"#fff",
"navigationBarBackgroundColor":"#000",
"navigationBarTitleText":"CNODE 应用号版",
"navigationBarTextStyle":"white",
"enablePullDownRefresh":"true"
},
效果如图
{
"pages":[
"pages/index/index",
"pages/logs/logs"
],
"window":{
"backgroundTextStyle":"black",
"backgroundColor":"#fff",
"navigationBarBackgroundColor":"#000",
"navigationBarTitleText":"CNODE 应用号版",
"navigationBarTextStyle":"white",
"enablePullDownRefresh":"true"
},
"tabBar":{
"color":"#272636",
"selectedColor":"#80bd01",
"backgroundColor":"#fff",
"borderStyle":"white",
"list":[{
"pagePath":"pages/index/index",
"text":"首页",
"iconPath":"images/tabBar/my.png",
"selectedIconPath":"images/tabBar/my_hl.png"
},{
"pagePath":"pages/index/index",
"text":"我的",
"iconPath":"images/tabBar/list.png",
"selectedIconPath":"images/tabBar/list_hl.png"
}]
}
}
根据官方要求,我在 pages 文件夹内创建了 topics 文件夹,并创建了对应了 topics.js 、 topics.wxml 、 topics.wxss 三个文件。
首先在配置文件里注册这个 topics,
"pages":[
"pages/topics/topics",
"pages/index/index",
"pages/logs/logs"
],
并且制定 tabBar 点击跳到对应的 topics 页面
"tabBar":{
"color":"#272636",
"selectedColor":"#80bd01",
"backgroundColor":"#fff",
"borderStyle":"white",
"list":[{
"pagePath":"pages/topics/topics",
"text":"首页",
"iconPath":"images/tabBar/my.png",
"selectedIconPath":"images/tabBar/my_hl.png"
},{
"pagePath":"pages/index/index",
"text":"我的",
"iconPath":"images/tabBar/list.png",
"selectedIconPath":"images/tabBar/list_hl.png"
}]
}
"pages/topics/topics"
放到了"pages/index/index"
的前面然后编写 topics.js
Page({
data: {
title: '首页列表'
},
onLoad: function () {
console.log('onLoad by topics');
}
});
以及 topics.wxml 文件
<view class="topics-main">
测试首页列表界面
</view>
和 topics.wxss 文件
.topics-main {
background: #f60;
height: 100%;
}
最后效果如图
根据文档请求数据,在 util 文件夹内创建一个 api.js 文件,专门进行数据请求处理。
'use strict';
var HOST_URI = 'https://cnodejs.org/api/v1';
var GET_TOPICS = '/topics';
var GET_TOPIC_BY_ID = '/topic/';
function obj2uri (obj) {
return Object.keys(obj).map(function (k) {
return encodeURIComponent(k) + '=' + encodeURIComponent(obj[k]);
}).join('&');
}
module.exports = {
// 获取列表数据
getTopics: function (obj) {
return HOST_URI + GET_TOPICS + '?' + obj2uri(obj);
},
// 获取内容页数据
getTopicByID: function (id, obj) {
return HOST_URI + GET_TOPIC_BY_ID + id + '?' + obj2uri(obj);
}
};
修改 topics.js
var Api = require('../../utils/api.js');
Page({
data: {
title: '首页列表'
},
onLoad: function () {
console.log('onLoad by topics');
this.fetchData();// 获取数据
},
fetchData: function (data) {
// 处理参数
if (!data) data = {};
if (!data.page) data.page = 1;
wx.request({
url: Api.getTopics(data),
success: function (res) {
console.log(res);
}
});
}
});
效果如图
拿到了数据,也能修改界面,那么就直接完善这个首页吧
代码就不放了,直接上图
<loading hidden="{{hidden}}">
加载中...
</loading>
在 topics.wxml 中写官方提供的 loading 组件,根据在 topics.js 中对 hidden 值的修改,来触发 loading 。
文档提供了列表渲染
通过wx:for
实现列表的渲染。
<block wx:for="{{postsList}}">
<view class="posts-item" index="{{index}}" id="{{item.id}}" catchtap="redictDetail">
<view class="author">
<image class="author-avatar" src="{{item.author.avatar_url}}"></image>
<view class="author-name">{{item.author.loginname}}</view>
<view class="posts-tag hot" wx:if="{{item.top === true}}">置顶</view>
<view class="posts-tag" wx:if="{{item.good === true}}">精华</view>
<view class="posts-last-reply">{{item.last_reply_at}}</view>
</view>
<view class="posts-title">{{item.title}}</view>
<view class="bar-info">
<view class="bar-info-item">
<image class="bar-info-item-icon" src="/images/icon/reply.png"></image>
<view class="bar-info-item-number">{{item.reply_count}}</view>
</view>
<view class="bar-info-item">
<image class="bar-info-item-icon" src="/images/icon/visit.png"></image>
<view class="bar-info-item-number">{{item.visit_count}}</view>
</view>
</view>
</view>
</block>
附上一个没有样式的列表展现
根据 cnode 的 api 可以知道通过 tab 不同的值,获得到不同标签下的内容列表。
所以 在页面的最上面 tab 栏中
<view class="top-bar">
<view class="top-bar-item" id="all" catchtap="onTapTag">全部</view>
<view class="top-bar-item" id="good" catchtap="onTapTag">精华</view>
<view class="top-bar-item" id="share" catchtap="onTapTag">分享</view>
<view class="top-bar-item" id="ask" catchtap="onTapTag">问答</view>
<view class="top-bar-item" id="job" catchtap="onTapTag">招聘</view>
</view>
将 id 进行定义,通过获取 id 拿到对应的 tab 类型。
其中catchtap
是事件绑定。
bind 事件绑定不会阻止冒泡事件向上冒泡, catch 事件绑定可以阻止冒泡事件向上冒泡。
在 topics.js 获取
onTapTag: function (e) {
var self = this;
var tab = e.currentTarget.id;
// 这里就能获取到不同的 tab 值了
self.setData({
tab: tab
});
if (tab !== 'all') {
this.fetchData({tab: tab});
} else {
this.fetchData();
}
},
根据文档,组件的视图容器中有scroll-view这个可滚动视图区域。
<scroll-view class="posts-list" style="height:100%" scroll-y="true" bindscrolltolower="lower">
<block wx:for="{{postsList}}">
...
</block>
</scroll-view>
topics.js 文件
lower: function (e) {
var self = this;
// 修改当前页码
self.setData({
page: self.data.page + 1
});
// 判断当前页的 tab 值 进行请求数据
if (self.data.tab !== 'all') {
this.fetchData({tab: self.data.tab, page: self.data.page});
} else {
this.fetchData({page: self.data.page});
}
}
在posts-item
中已经进行了事件绑定。利用wx.navigateTo
实现页面的跳转。
redictDetail: function (e) {
console.log('我要看详情');
var id = e.currentTarget.id,
url = '../detail/detail?id=' + id;
// 这里的 detail 是需要创建对应的文件,以及页面注册的
wx.navigateTo({
url: url
})
},
同样的原理,创建 detail 文件,并注册,获取数据,并美化页面。
放上我的 github 地址 https://github.com/coolfishstudio/wechat-webapp-cnode
最后感谢: cnode 社区和博卡君
附上 博卡君的教程
博卡君的应用号(小程序)开发教程首发第二弹!( 0923 )
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.