ホームページ >WeChat アプレット >WeChatの開発 >WeChat開発実践知乎日報
ミニ プログラムの紹介をたくさん読んだ後は、ミニ プログラムについてある程度の理解を持っている必要があります。この記事では、入門には焦点を当てません。ここでは、Zhihu Daily ミニ プログラムを通じて実践して、WeChat ミニ プログラム API についての理解を深めていきます。
さて、始めましょう。
まずは今日行う知乎日報の結果を見てみましょう。
以下に示すように。ただし、スペースの問題のため、今日はホームページの完成についてのみ説明します。これには、バックエンドとの対話、ページ レイアウト、データ レンダリング、イベント応答などが含まれます。基本的に、ホームページの作成方法のすべての開発がカバーされています。単一ページ。
Zhihu Daily - 簡易版 API:
new s-at.zhihu.com/api/4/news/latest 今日热文 news.at.zhihu.com/api/4/news/ before / 更多往日热文
上記の 2 つのアドレスは、今日行う予定のホームページの API です。リクエストリクエストを開始し、レンダリング用のデータを取得します。
次に、ホームページのディレクトリ構造を以下の図と一致させてください。
それでは、まず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 }, })
ここで、いくつかの重要なポイントについて簡単に説明します:
現在、WeChat アプレットは
this.setData({....});
のみをサポートし、値を直接指定することはできません
this.data.xxxx = ''; //记住,这样是不行的。
これはページです ライフサイクル ページの読み込みを監視する方法。このページに入るたびに、内部のメソッドを実行する必要があります。これは、JS の読み込みと同じです。
WeChat アプレットもバックエンドと対話するためにリクエスト インターフェイスを使用します。具体的なサンプルは次のとおりです。誰もが理解できるようにコメントを追加しました。
wx.request({ url: 'test.php', //接口地址 data: { // 参数 x: '' , y: '' }, header: { // 头信息 'Content-Type': 'application/json' }, success: function(res) { // 成功 回调 console.log(res.data) } })
さて、バックエンドと対話する JS コードの記述が完了したので、データを取得します。次に、ページ レイアウトの記述を開始します。
実際、WeChat アプレットはページをレンダリングするときに テンプレート エンジン メソッドも使用します。また、ページ値メソッドは比較的一般的です。これは他のページ テンプレート エンジンと似ています。
さて、始めましょう。この ページ レイアウトは比較的シンプルです。
まず、ドキュメントに移動します。特別なバナーコンポーネントがあり、
スワイパー(クリックしてドキュメントにジャンプします)
これを使用します書き込む 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>
其实下面的一个热闻列表也就是一个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
コンポーネントの wx:for コントロール属性を使用して配列をバインドすると、コンポーネントは配列内の各項目のデータを使用して繰り返しレンダリングできます。デフォルトでは、配列内の現在の項目の添字変数名はデフォルトでインデックスになり、配列内の現在の項目の変数名はデフォルトで 項目になります。変更する必要がある場合は、wx を使用します。 for-item は、配列の現在の要素の変数名を指定します。
item.header
には驚かないでください。アイテムはどこから来たのでしょうか? コードは次のとおりです: rrreee さらに、bindtap
属性を使用して応答メソッド名を指定する、さらにクリック応答があります。
2. PigCms マイクロ電子商取引システム オペレーティング バージョン (独立したマイクロ ストア モール + 3 レベルの配信システム)
3. WeChat People Network v3.4.5 Advanced Business Edition WeChat ルービック キューブ ソース コード
以上がWeChat開発実践知乎日報の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。