微信小程序 cnode社區(qū)版本

微信小程序 cnode社區(qū)版本

官方文檔:https://mp.weixin.qq.com/debug/wxadoc/dev/

參考資料:https://github.com/coolfishstudio/wechat-webapp-cnode

小程序預覽

demo2.gif
8.png

項目結構

<pre>
│ .gitattributes
│ .gitignore
│ app.js # 小程序邏輯
│ app.json # 小程序公共設置(頁面路徑岖寞、窗口表現(xiàn)、設置網(wǎng)絡超時時間、設置多tab)
│ app.wxss # 小程序公共樣式表
│ README.md # 小程序項目說明

├─image # 小程序圖片資源
|
├─pages # 小程序文件
│ ├─common
│ ├─detail
│ ├─index
│ │ index.js # 頁面邏輯
│ │ index.wxml # 頁面渲染層
│ │ index.wxss # 頁面樣式
│ ├─login
| ├─logs
│ └─topics

└─utils # 小程序公用方法模塊
api.js
util.js
</pre>

開發(fā)環(huán)境

下載地址 :https://mp.weixin.qq.com/debug/wxadoc/dev/devtools/download.html?t=1474887501214

開發(fā)過程

  1. 配置默認啟動頁面

在app.json文件修改注冊頁面的順序,把“pages/topics/topics” 放在第一位,就會自動把topics.wxml 顯示默認啟動

<pre>
{
"pages":[
"pages/topics/topics",
"pages/detail/detail",
"pages/login/login",
"pages/index/index",
"pages/logs/logs"
]
}
</pre>

  1. 配置tabBar

    tabBar 是一個數(shù)組,只能配置最少2個、最多5個 tab蜀踏,tab 按數(shù)組的順序排序。

<pre>
"tabBar":{
"color":"#444",
"selectedColor":"#80bd01",
"backgroundColor":"#fff",
"borderStyle":"white",
"list":[{
"pagePath":"pages/topics/topics",
"text":"首頁",
"iconPath":"images/bar/CNode.png",
"selectedIconPath":"images/bar/CNodeHL.png"
},{
"pagePath":"pages/index/index",
"text":"我的",
"iconPath":"images/bar/ME.png",
"selectedIconPath":"images/bar/MEHL.png"
}]
}
</pre>

  1. window 設置

    具體看文檔https://mp.weixin.qq.com/debug/wxadoc/dev/framework/config.html?t=1475052056717

  2. 簡單封裝wx.request(OBJECT)

<pre>
// get請求方法
function fetchGet(url, callback) {
// return callback(null, top250)
wx.request({
url: url,
header: { 'Content-Type': 'application/json' },
success (res) {
callback(null, res.data)
},
fail (e) {
console.error(e)
callback(e)
}
})
}

// post請求方法
function fetchPost(url, data, callback) {
  wx.request({
    method: 'POST',
    url: url,
    data: data,
    success (res) {
      callback(null, res.data)
    },
    fail (e) {
      console.error(e)
      callback(e)
    }
  })
}

module.exports = {
  // METHOD
  fetchGet: fetchGet,
  fetchPost: fetchPost
}

</pre>

  1. 滾動底部加載下一頁

使用了小程序自帶的scroll-view組件

2.png
  <!--列表list組件 -->
  <template name="list">
    <scroll-view class="scroll-posts-list" style="height:100%" scroll-y="true" bindscrolltolower="lower">
      <view class="postslist">
        <block wx:for="{{postsList}}">
          <view class="posts-list">
            <navigator url="/pages/detail/detail?id={{item.id}}">
              <view class="posts-list-info" index="{{index}}">
                  <image class="userimg" src="{{item.author.avatar_url}}" />
                  <view class="item-box">
                    <view class="userinfo">
                      <text class="username">{{item.author.loginname}}</text>
                      <text class="time">{{item.last_reply_at}}</text>
                    </view>
                    <view class="posts-title">
                      <view class="posts-tag hot" wx:if="{{item.top === true}}">置頂</view>
                      <view class="posts-tag" wx:if="{{item.good === true}}">精華</view>
                      <text>{{item.title}}</text>
                    </view>
                  </view>
              </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 class="bar-info-item2"  wx:if="{{item.tab === 'good'}}">
                  <image class="bar-info-item-icon" src="/images/icon/type.png"></image>
                  <view class="bar-info-item-number">精華</view>
                </view>
                <view class="bar-info-item2"  wx:if="{{item.tab === 'share'}}">
                  <image class="bar-info-item-icon" src="/images/icon/type.png"></image>
                  <view class="bar-info-item-number">分享</view>
                </view>
                <view class="bar-info-item2"  wx:if="{{item.tab === 'ask'}}">
                  <image class="bar-info-item-icon" src="/images/icon/type.png"></image>
                  <view class="bar-info-item-number">問答</view>
                </view>
                <view class="bar-info-item2"  wx:if="{{item.tab === 'job'}}">
                  <image class="bar-info-item-icon" src="/images/icon/type.png"></image>
                  <view class="bar-info-item-number">招聘</view>
                </view>
              </view>
          </navigator>
          </view>
        </block>
      </view>
    </scroll-view>

    <loading class="loading" hidden="{{hidden}}">
      <text class="loading-font">加載中...</text>
    </loading>
  </template>
  <!-- topics.wxml  -->
  <import src="../common/nav.wxml"/>
  <import src="../common/list.wxml"/>

  <view class="page topics">
    <template is="nav" data="{{ navList, activeIndex }}"/>
    <template is="list" data="{{ postsList, hidden }}"/>
  </view>

滾動區(qū)的最大的父級層要設置height: 100%; 不然無法檢測滾動事件
也不知道是不是我布局的原因掰吕,我這里是一定要這樣設置的

.topics{
  height: 100%;
  overflow: hidden;
}
// 滑動底部加載
lower: function() {
  console.log('滑動底部加載', new Date());
  var that = this;
  that.setData({
    page: that.data.page + 1
  });
  if (that.data.tab !== 'all') {
    this.getData({tab: that.data.tab, page: that.data.page});
  } else {
    this.getData({page: that.data.page});
  }
}

用法

  <scroll-view class="scroll-posts-list" style="height:100%" scroll-y="true" bindscrolltolower="lower">
  </scroll-view>

使用說明

  1. 將倉庫克隆到本地:
$ git clone https://github.com/vincentSea/wechat-cnode.git
  1. 打開微信Web開放者工具(注意:必須是0.9.092300版本)

  2. 選擇添加項目果覆,填寫或選擇相應信息

  • AppID:點擊右下角無AppID
  • 項目名稱:隨便填寫,因為不涉及到部署殖熟,所以無所謂
  • 項目目錄:選擇剛剛克隆的文件夾
  • 點擊添加項目

特別感謝

感謝 coolfish 的項目案例

coolfish的github: https://github.com/coolfishstudio

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末随静,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌燎猛,老刑警劉巖恋捆,帶你破解...
    沈念sama閱讀 210,978評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異重绷,居然都是意外死亡沸停,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評論 2 384
  • 文/潘曉璐 我一進店門昭卓,熙熙樓的掌柜王于貴愁眉苦臉地迎上來愤钾,“玉大人,你說我怎么就攤上這事候醒∧馨洌” “怎么了?”我有些...
    開封第一講書人閱讀 156,623評論 0 345
  • 文/不壞的土叔 我叫張陵倒淫,是天一觀的道長伙菊。 經(jīng)常有香客問我,道長敌土,這世上最難降的妖魔是什么镜硕? 我笑而不...
    開封第一講書人閱讀 56,324評論 1 282
  • 正文 為了忘掉前任,我火速辦了婚禮返干,結果婚禮上兴枯,老公的妹妹穿的比我還像新娘。我一直安慰自己矩欠,他們只是感情好财剖,可當我...
    茶點故事閱讀 65,390評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著癌淮,像睡著了一般躺坟。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上该默,一...
    開封第一講書人閱讀 49,741評論 1 289
  • 那天瞳氓,我揣著相機與錄音策彤,去河邊找鬼栓袖。 笑死,一個胖子當著我的面吹牛店诗,可吹牛的內容都是我干的裹刮。 我是一名探鬼主播,決...
    沈念sama閱讀 38,892評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼庞瘸,長吁一口氣:“原來是場噩夢啊……” “哼捧弃!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,655評論 0 266
  • 序言:老撾萬榮一對情侶失蹤违霞,失蹤者是張志新(化名)和其女友劉穎嘴办,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體买鸽,經(jīng)...
    沈念sama閱讀 44,104評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡涧郊,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了眼五。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片妆艘。...
    茶點故事閱讀 38,569評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖看幼,靈堂內的尸體忽然破棺而出批旺,到底是詐尸還是另有隱情,我是刑警寧澤诵姜,帶...
    沈念sama閱讀 34,254評論 4 328
  • 正文 年R本政府宣布汽煮,位于F島的核電站,受9級特大地震影響茅诱,放射性物質發(fā)生泄漏逗物。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,834評論 3 312
  • 文/蒙蒙 一瑟俭、第九天 我趴在偏房一處隱蔽的房頂上張望翎卓。 院中可真熱鬧,春花似錦摆寄、人聲如沸失暴。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽逗扒。三九已至,卻和暖如春欠橘,著一層夾襖步出監(jiān)牢的瞬間矩肩,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評論 1 264
  • 我被黑心中介騙來泰國打工肃续, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留黍檩,地道東北人。 一個月前我還...
    沈念sama閱讀 46,260評論 2 360
  • 正文 我出身青樓始锚,卻偏偏與公主長得像刽酱,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子瞧捌,可洞房花燭夜當晚...
    茶點故事閱讀 43,446評論 2 348

推薦閱讀更多精彩內容

  • 微信小程序 cnode社區(qū)版本 官方文檔:https://mp.weixin.qq.com/debug/wxado...
    vincentSea閱讀 1,187評論 2 0
  • afinalAfinal是一個android的ioc棵里,orm框架 https://github.com/yangf...
    passiontim閱讀 15,406評論 2 45
  • 一個人活在自己的世界润文,一個人思考、一個人行動殿怜、一個人孤獨典蝌,容易走入心靈僻境。導致的后果头谜,就是脫離了關系赠法,內心容易脆...
    w小郭閱讀 417評論 0 0
  • 近年來,區(qū)塊鏈技術(部分人更愿意稱之為分布式賬本技術)的走紅將分布式技術的概念帶入大眾的視野乔夯。區(qū)塊鏈技術之所以備受...
    Li_Heng_lius閱讀 28,151評論 24 87
  • 有的時候末荐,越是想記起一個人侧纯,越是想不起來你的樣子。閉上眼甲脏,望著天眶熬,只有模糊的一片,還有块请,你嘴角彎起的弧線…… 在這...
    安小安zzz閱讀 10,009評論 51 60