ホームページ  >  記事  >  WeChat アプレット  >  WeChat開発実践知乎日報

WeChat開発実践知乎日報

零下一度
零下一度オリジナル
2017-05-22 11:26:342159ブラウズ

まえがき

ミニ プログラムの紹介をたくさん読んだ後は、ミニ プログラムについてある程度の理解を持っている必要があります。この記事では、入門には焦点を当てません。ここでは、Zhihu Daily ミニ プログラムを通じて実践して、WeChat ミニ プログラム API についての理解を深めていきます。

さて、始めましょう。

いよいよ実戦開始

まずは今日行う知乎日報の結果を見てみましょう。
以下に示すように。ただし、スペースの問題のため、今日はホームページの完成についてのみ説明します。これには、バックエンドとの対話、ページ レイアウト、データ レンダリング、イベント応答などが含まれます。基本的に、ホームページの作成方法のすべての開発がカバーされています。単一ページ。

WeChat開発実践知乎日報

Zhihu Daily ミニプログラムのホームページ

1. リソースの準備

Zhihu Daily - 簡易版 API:

new
s-at.zhihu.com/api/4/news/latest 今日热文
news.at.zhihu.com/api/4/news/
before
/  更多往日热文

上記の 2 つのアドレスは、今日行う予定のホームページの API です。リクエストリクエストを開始し、レンダリング用のデータを取得します。

2. ホームページ JS

次に、ホームページのディレクトリ構造を以下の図と一致させてください。

WeChat開発実践知乎日報

ホームページ上の3つのファイル

それでは、まずJSファイルを書きましょう。コードは次のとおりで、詳細なコメントを追加しました。

// index.js

//index.js
//获取应用实例
var app = getApp()
var utils = require('../../utils/util.js');
//初始化数据
Page({
  data: {
    list: [],
    duration: 2000,
    indicatorDots: true,
    autoplay: true,
    interval: 3000,
    loading: false,
    plain: false
  },
  //onLoad方法,程序启动自执行,请求知乎日报今日热闻接口
  onLoad: function () {
    var that = this;
    wx.request({
      url: 'http://news-at.zhihu.com/api/4/news/latest',
      headers: { // http头数据
        'Content-Type': 'application/json'
      },
      success: function (res) { //请求成功后的回调
         that.setData({   // 设置返回值
           banner: res.data.top_stories,  //banner图片数据
           list: [{ header: '今日热闻' }].concat(res.data.stories)  //热闻数据list
         })
      }
    })
    this.index = 1;   //方便下拉点击更多时的计数下标,暂可忽略
  },
  //下拉滚动条,点击更多的响应
  loadMore: function (e) {
    if (this.data.list.length === 0) return
    var date = this.getNextDate()
    var that = this
    that.setData({ loading: true });
    wx.request({  // 再次发起请求,请求上一天的热闻
      url: 'http://news.at.zhihu.com/api/4/news/before/' + (Number(utils.formatDate(date)) + 1),  //此此API需要带日期
      headers: {
        'Content-Type': 'application/json'
      },
      success: function (res) {  // 成功回调
         that.setData({
           loading: false,
           list: that.data.list.concat([{ header: utils.formatDate(date, '-') }]).concat(res.data.stories)
         })
      }
    })
  },
  //事件处理函数
  bindViewTap: function(e) {
    wx.navigateTo({
      url: '../detail/detail?id=' + e.target.dataset.id
    })
  },
  //转换时间函数
  getNextDate: function (){
    var now = new Date()
    now.setDate(now.getDate() - this.index++)
    return now
  },

})

ここで、いくつかの重要なポイントについて簡単に説明します:

2.1 データ値の設定

現在、WeChat アプレットは

this.setData({....});

のみをサポートし、値を直接指定することはできません

this.data.xxxx = '';  //记住,这样是不行的。
2.2 onLoad

これはページです ライフサイクル ページの読み込みを監視する方法。このページに入るたびに、内部のメソッドを実行する必要があります。これは、JS の読み込みと同じです。

2.3 サーバーとの対話

WeChat アプレットもバックエンドと対話するためにリクエスト インターフェイスを使用します。具体的なサンプルは次のとおりです。誰もが理解できるようにコメントを追加しました。

wx.request({
  url: 'test.php', //接口地址
  data: {  // 参数
     x: '' ,
     y: ''
  },
  header: {  // 头信息
      'Content-Type': 'application/json'
  },
  success: function(res) {  // 成功 回调
    console.log(res.data)
  }
})

3. ホームページのレイアウト Index.html

さて、バックエンドと対話する JS コードの記述が完了したので、データを取得します。次に、ページ レイアウトの記述を開始します。

実際、WeChat アプレットはページをレンダリングするときに テンプレート エンジン メソッドも使用します。また、ページ値メソッドは比較的一般的です。これは他のページ テンプレート エンジンと似ています。

さて、始めましょう。この ページ レイアウトは比較的シンプルです。

WeChat開発実践知乎日報

レイアウト分割

3.1バナーブロック

まず、ドキュメントに移動します。特別なバナーコンポーネントがあり、
スワイパー(クリックしてドキュメントにジャンプします)

これを使用します書き込む swiper コンポーネント バナー モジュールについて注意すべき点があります

b60ffe63992775b91f84d57c1529dfc3 コンポーネントのみを swiper コンポーネントに配置できます他のノードは自動的に削除されます。 swiper 组件中只可放置b60ffe63992775b91f84d57c1529dfc3组件,其他节点会被自动删除。

// index.html banner模块代码

<swiper indicator-dots="{{indicatorDots}}"
  autoplay="{{autoplay}}" class="banners" interval="{{interval}}" duration="{{duration}}">
    <!-- 循环bannner图片开始-->
    <block wx:for="{{banner}}"> 
      <swiper-item class="banner" >
          <image src="{{item.image}}"  data-id="{{item.id}}" bindtap="bindViewTap" class="banner-image" width="100%" height="100%"/>
          <text class="banner-title">{{item.title}}</text>
      </swiper-item>
    </block>
     <!-- 循环bannner图片结束-->
  </swiper>
3.2 热闻列表模块

其实下面的一个热闻列表也就是一个list循环,这边怎么做循环呢,同样我们可以查询API文档可得。
利用 wx-for 属性,但是这只是一个属性,我们需要把它加到一个标签上面才能执行,为了承载这个属性,微信小程序专门定义了一个无其他作用的标签 11606cc87d8fd89bcb19e3fd11c7bb4b。

另外注意,微信小程序里有很多默认:

在组件上使用wx:for控制属性绑定一个数组,即可使用数组中各项的数据重复渲染该组件。默认数组的当前项的下标变量名默认为index,数组当前项的变量名默认为item,如果需要修改的话,使用 wx:for-item 可以指定数组当前元素的变量名。

所以对下面的item.header不要惊讶,item哪来的。

代码如下:

<view class="news-item-container">
    <block wx:for="{{list}}" wx:for-index="id">
      <text wx:if="{{item.header}}" class="sub-title">{{item.header}}</text>
      <navigator wx:else url="../detail/detail?id={{item.id}}">
        <view class="news-item" >
          <view class="news-item-left">
            <text class="news-item-title">{{item.title}}</text>
          </view>
          <view class="news-item-right">
            <image src="{{item.images[0]}}" class="news-image"/>
          </view>
        </view>
      </navigator>
    </block>
    <button type="primary" class="load-btn" size="mini" loading="{{loading}}" plain="{{plain}}" bindtap="loadMore"> 更多 </button>
  </view>

另外,这里有个更多的点击响应,使用的是 bindtap

rrreee

3.2 ホットニュースリストモジュール 実際、以下のホットニュースリストもリストループです。ここでループを作成する方法は、API ドキュメントをクエリして取得することもできます。

wx-for 属性を使用しますが、これは単なる属性であり、この属性を実行するには、WeChat アプレットは他の機能を持たないラベル 11606cc87d8fd89bcb19e3fd11c7bb4b を明確に定義します。 。

WeChat ミニ プログラムには多くのデフォルトがあることにも注意してください:

コンポーネントの wx:for コントロール属性を使用して配列をバインドすると、コンポーネントは配列内の各項目のデータを使用して繰り返しレンダリングできます。デフォルトでは、配列内の現在の項目の添字変数名はデフォルトでインデックスになり、配列内の現在の項目の変数名はデフォルトで 項目になります。変更する必要がある場合は、wx を使用します。 for-item は、配列の現在の要素の変数名を指定します。

では、次の item.header には驚かないでください。アイテムはどこから来たのでしょうか?

コードは次のとおりです:

rrreee さらに、bindtap 属性を使用して応答メソッド名を指定する、さらにクリック応答があります。

4. スタイルシートインデックス🎜wxss🎜🎜🎜これについては個別に説明しませんが、通常書くCSSとほぼ同じです。最後に、ソース コードが公開され、誰でもダウンロードできるようになります。 🎜🎜5. 最後に書かれています 🎜🎜この小さな記事は、WeChat アプレットについての理解を深めるために、サーバーと対話する小さなデモを作成するためのものです。 🎜フォローアップは現在コーディング中です....🎜お楽しみに。 🎜🎜【関連する推奨事項】🎜🎜1. 🎜WeChatパブリックアカウントプラットフォームのソースコードのダウンロード🎜🎜

2. PigCms マイクロ電子商取引システム オペレーティング バージョン (独立したマイクロ ストア モール + 3 レベルの配信システム)

3. WeChat People Network v3.4.5 Advanced Business Edition WeChat ルービック キューブ ソース コード

以上がWeChat開発実践知乎日報の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。