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

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

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

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

小程序預(yù)覽

demo2.gif
8.png

項(xiàng)目結(jié)構(gòu)

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

├─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. 配置默認(rèn)啟動(dòng)頁面

在app.json文件修改注冊(cè)頁面的順序,把“pages/topics/topics” 放在第一位,就會(huì)自動(dòng)把topics.wxml 顯示默認(rèn)啟動(dòng)

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

  1. 配置tabBar

    tabBar 是一個(gè)數(shù)組,只能配置最少2個(gè)、最多5個(gè) 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 設(shè)置

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

  2. 簡(jiǎn)單封裝wx.request(OBJECT)

<pre>
// get請(qǐng)求方法
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請(qǐng)求方法
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. 滾動(dòng)底部加載下一頁

使用了小程序自帶的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>

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

.topics{
  height: 100%;
  overflow: hidden;
}
// 滑動(dòng)底部加載
lower: function() {
  console.log('滑動(dòng)底部加載', 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. 將倉(cāng)庫(kù)克隆到本地:
$ git clone https://github.com/vincentSea/wechat-cnode.git
  1. 打開微信Web開放者工具(注意:必須是0.9.092300版本)

  2. 選擇添加項(xiàng)目,填寫或選擇相應(yīng)信息

  • AppID:點(diǎn)擊右下角無AppID
  • 項(xiàng)目名稱:隨便填寫,因?yàn)椴簧婕暗讲渴穑詿o所謂
  • 項(xiàng)目目錄:選擇剛剛克隆的文件夾
  • 點(diǎn)擊添加項(xiàng)目

特別感謝

感謝 coolfish 的項(xiàng)目案例

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

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,835評(píng)論 6 534
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,676評(píng)論 3 419
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,730評(píng)論 0 380
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,118評(píng)論 1 314
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,873評(píng)論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,266評(píng)論 1 324
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,330評(píng)論 3 443
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,482評(píng)論 0 289
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,036評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,846評(píng)論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,025評(píng)論 1 371
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,575評(píng)論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,279評(píng)論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,684評(píng)論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,953評(píng)論 1 289
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,751評(píng)論 3 394
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,016評(píng)論 2 375

推薦閱讀更多精彩內(nèi)容

  • 微信小程序 cnode社區(qū)版本 官方文檔:https://mp.weixin.qq.com/debug/wxado...
    vincentSea閱讀 1,209評(píng)論 2 0
  • afinalAfinal是一個(gè)android的ioc,orm框架 https://github.com/yangf...
    passiontim閱讀 15,467評(píng)論 2 45
  • 一個(gè)人活在自己的世界,一個(gè)人思考、一個(gè)人行動(dòng)、一個(gè)人孤獨(dú),容易走入心靈僻境。導(dǎo)致的后果,就是脫離了關(guān)系,內(nèi)心容易脆...
    w小郭閱讀 430評(píng)論 0 0
  • 近年來,區(qū)塊鏈技術(shù)(部分人更愿意稱之為分布式賬本技術(shù))的走紅將分布式技術(shù)的概念帶入大眾的視野。區(qū)塊鏈技術(shù)之所以備受...
    Li_Heng_lius閱讀 28,287評(píng)論 24 87
  • 有的時(shí)候,越是想記起一個(gè)人,越是想不起來你的樣子。閉上眼,望著天,只有模糊的一片,還有,你嘴角彎起的弧線…… 在這...
    安小安zzz閱讀 10,030評(píng)論 51 60