ホームページ > WeChat アプレット > ミニプログラム開発 > WeChat ミニ プログラムを開発するとき、なぜ upData だけを使用するのですか?

WeChat ミニ プログラムを開発するとき、なぜ upData だけを使用するのですか?

coldplay.xixi
リリース: 2020-09-27 17:02:33
転載
2295 人が閲覧しました

WeChat ミニ プログラムを開発するとき、なぜ upData だけを使用するのですか?

WeChat アプレットの開発時に setData を使用した経験が乏しいことを考慮して、ライブラリ関数 wx-updata を開発しました。がリリースされました, この自己使用ライブラリ関数をコンパイルし、オープンソース wx-updata として Github に置きました. このライブラリ関数は開発中に非常に役に立ちました. 皆さんにも役立つことを願っています. 使用中に問題が発生した場合, 問題がある場合は、PR または問題を私に送信して、ミニ プログラム開発エクスペリエンスを向上させるために一緒に働きましょう~

  • wx-updata

    バージョン 0.0.10

  • Github アドレス: github.com/SHERlocked9…
  • ミニ プログラム コード スニペットのプレビュー アドレス: developers.weixin.qq .com/s/CcXdO1mc7…
  • ミニ プログラム コード スニペット コード アドレス: github.com/SHERlocked9…
  • 1. setData

を使用しています

setData

のときに不快に感じることがありますか? 以下に簡単な例を示します: <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false;">// 你的 datadata: { name: &amp;#39;蜡笔小新&amp;#39;, info: { height: 140, color: &amp;#39;黄色&amp;#39; } }复制代码</pre><div class="contentsignin">ログイン後にコピー</div></div>

info.height## を変更したい場合# から 155 までは、

を使用します。 setData の実行方法:

// 这样会把 info 里其他属性整不见了this.setData({ info: { height: 155 } })// 你需要取出 info 对象,修改后整个 setDataconst { info } = this.data
info.height = 155this.setData({ info })复制代码
ログイン後にコピー
はそれほど複雑ではないようですが、data

が大きなオブジェクトの場合は、深くて異なるオブジェクトと配列項目が必要になります。 :

data: {    name: &#39;蜡笔小新&#39;,    info: {        height: 140, color: &#39;黄色&#39;,        desc: [{ age: 8 }, &#39;最喜欢大象之歌&#39;, &#39;靓仔&#39;, { dog: &#39;小白&#39;, color: &#39;白色&#39; }]
    }
}复制代码
ログイン後にコピー
たとえば、特定の要件では、info.height

を 155 に変更し、同時に

age を変更する必要があります。 info.desc 配列の 0 番目の項目の は 12、3 番目の項目の color はグレー?

// 先取出要改变的对象,改变数字后 setData 回去const { info } = this.data
info.height = 155info.desc[0].age = 12info.desc[3].color = &#39;灰色&#39;this.setData({ info })// 或者像某些文章里介绍的,这样可读性差,也不太实用this.setData({    &#39;info.height&#39;: 155,    &#39;info.desc[0].age&#39;: 12,    &#39;info.desc[3].color&#39;: &#39;灰色&#39;})复制代码
ログイン後にコピー
上記の2つのメソッドは日常のちょっとしたプログラムでよく使われますが、他のWeb側のフレームワークと比べると非常にダサくて中途半端な印象が強いです。 :
this.upData({    info: {        height: 155,        desc: [{ age: 12 }, , , { color: &#39;灰色&#39; }]
    }
})复制代码
ログイン後にコピー

このメソッドは、ネストされたオブジェクト内の対応する属性値を大幅に変更し、変更したくない配列項目をスキップして、属性値のみを設定するのに役立ちます。と配列項目を提供しました。省略されていませんか? 非常に読みやすい、くだらないコードがたくさんあります。

これが、オンライン プロジェクトで

setData の代わりに wx-updata を使用する理由です。

wx-updata の原理は、実際には非常に単純です。次に例を示します。

this.upData({    info: {        height: 155,        desc: [{ age: 12 }]
    }
})// 会被自动转化为下面这种格式,// this.setData({//    &#39;info.height&#39;: 155,//    &#39;info.desc[0].age&#39;: 12,// })复制代码
ログイン後にコピー

元々はこの変換を自分たちで手動で行う必要がありましたが、今では wx-updata が代わりに変換を行ってくれます。素晴らしいですね!

wx-updataのメリットと主な利用方法を紹介します~

2. wx-updataのメリット

Supports

setData
    オブジェクトの自動マージ、くだらないオブジェクト パスを記述する必要はありません
  1. オブジェクト内のネストされた配列、および配列内のネストされたオブジェクトをサポートします;
  2. 配列内の特定の値を上書きしたくない場合は、
  3. [1,,3]
  4. などの配列項目をスキップするには、配列スペースを使用してください。この配列の中央は配列の空スペースです。
  5. If your Eslint
  6. 配列が空の場合はエラーを報告します。
  7. wx-updata 代わりに Empty を指定します: [1, Empty, 3]使用されていない場合配列内のスペースを空にする場合、またはカンマを数えたくない場合は、配列のオブジェクト パス メソッドを試してください。[1,,3]
  8. ->
  9. {'[0]' : 1, '[2]': 3} 3. wx-updata のインストール

wx-updata を直接コピーすることもできます
dist

ディレクトリ内の .js を使用するプロジェクトに追加します

npm

yarn を使用しますインストール方法:

$ npm i -S wx-updata# or$ yarn add wx-updata复制代码
ログイン後にコピー
次に:

WeChat 開発者ツールをインストールします

パネルの右側にある詳細 - ローカル設定 - npm モジュール
    ボタンを使用して開きます;
  1. WeChat 開発者ツール パネル ツールバーの ツールをクリック - npm のビルド
  2. ;
  3. ビルド後、
  4. miniprogram_npm
フォルダーが正常に生成され、次のことが可能になります。

4. wx-updataの使い方

利用方法その1

Page

に直接マウントする方法が使えます。

setData

// app.jsimport { updataInit } from &#39;./miniprogram_npm/wx-updata/index&#39;  // 你的库文件路径App({
    onLaunch() {
        Page = updataInit(Page, { debug: true })
    }
})复制代码
ログイン後にコピー
// 页面代码中this.upData({    info: { height: 155 },    desc: [{ age: 13 }, &#39;帅哥&#39;],    family: [, , [, , , { color: &#39;灰色&#39; }]]
})复制代码
ログイン後にコピー
使用方法 2一部のフレームワークでは、Page インスタンスで setData

と同じように

upData

を使用できます。

Page オブジェクトにさらに変更が加えられており、Page を直接置き換えることはできない可能性があります。すばらしいですね。wx-updata はツール メソッドも公開しています。ユーザーはツールを使用できますメソッドをページ コード内で直接処理します:

// 页面代码中import { objToPath } from &#39;./miniprogram_npm/wx-updata/index&#39;  // 你的库文件路径Page({    data: { a: { b: 2}, c: [3,4,5]},    // 自己封装一下
    upData(data) {        return this.setData(objToPath(data))
    },    // 你的方法中或生命周期函数
    yourMethod() {        this.upData({ a: { b: 7}, c: [8,,9]})
    }
})复制代码
ログイン後にコピー

Empty を使用して配列の空のスペースを置き換えます

wx-updata によって提供される Empty を使用して、空の配列を置き換えることができますEmpty は本質的にシンボルであるため、wx-updata によってエクスポートされたもののみを使用でき、自分で作成することはできません。

// 页面代码中import { Empty } from &#39;./miniprogram_npm/wx-updata/index&#39;this.upData({    info: { height: 155 },    desc: [{ age: 13 }, &#39;帅哥&#39;],    family: [Empty, Empty, [Empty, Empty, Empty, { color: &#39;灰色&#39; }]]
})复制代码
ログイン後にコピー

配列のオブジェクト パス メソッド

配列内の空白スペースに慣れていない場合、またはカンマを数える気がない場合は、配列のオブジェクト パス メソッドを試すことができます。 config

{arrObjPath: true}

// 页面代码中import { Empty } from &#39;./miniprogram_npm/wx-updata/index&#39;// 原来的方式this.upData({    info: { height: 155 },    desc: [, &#39;靓仔&#39;],    family: [, , [, , , { color: &#39;灰色&#39; }]]
})// 使用数组路径方式this.upData({    info: { height: 155 },    desc: {&#39;[1]&#39;: &#39;靓仔&#39;},    family: { &#39;[2]&#39;: { &#39;[3]&#39;: { color: &#39;灰色&#39; }
})复制代码
ログイン後にコピー

5 の設定を渡す必要があります。wx-updata 関連の API

Page.prototype.upData(Object data,関数コールバック)

  1. data: 設定したいデータ
  2. callback: setData の 2 番目のパラメータと同じで、インターフェイスの後にコールバック関数が発生します。

#updataInit(Page, config)

  1. #Page: ページ オブジェクトは # にある必要があります。 ##app.js 呼び出されます;
  2. config
  3. 構成構成パラメータ
      { debug: true }
    • はパスされたデータを出力します, help ユーザー デバッグの場合、デフォルト値は false で有効ではありません。構成パラメータ
    • { arrObjPath: true }
    • により、配列のオブジェクト パス モード関数が有効になります。デフォルト値は次のとおりです。 false で有効ではありません;
objToPath(Object data, Object config)

    data
  1. : 設定するデータ オブジェクト
  2. config
  3. ConfigurationConfigurationparameters
      { arrObjPath: true }
    • 、オブジェクト パス モード機能が有効になります。配列のデフォルトは false で、有効になりません。
その他の関連する無料学習の推奨事項:

WeChat ミニ プログラムの開発

以上がWeChat ミニ プログラムを開発するとき、なぜ upData だけを使用するのですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:juejin.im
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート