模倣性の高いQQのWeChatアプレットの詳細説明
この記事は主に、SmallAppForQQ プロジェクトの進行中に遭遇した問題のいくつかについて書きます。この記事があなたのお役に立てば幸いです。
SmallAppForQQ: QQ にアクセスするための WeChat アプレット
記事の冒頭で、プロジェクトの構造を簡単に紹介します。開発ツールがインストールされていない場合は、
github.com/xiehui999/ にアクセスできます。 SmallAppForQQ
をダウンロードしてください。 WeChat ミニ プログラム プロジェクト構造には、次の 4 つの主要なファイル タイプがあります -
1) WXML ファイル: (Weixin マークアップ言語) は、前任者に基づいて WeChat によって設計された記述的なタグ言語のセットであり、構築に使用されます。ミニプログラムビュー。
2) WXSS ファイル: (WeiXin スタイル シート) は、wxml でビュー コンポーネントのスタイルを記述するために使用されるスタイル言語です。
3) js ファイル: ビジネス ロジック処理、バックエンドとのデータ対話など。
4) json ファイル: ページ登録、ページタイトルなどのミニプログラム設定ファイル。
注: 開発者が構成項目を減らしやすくするために、ページを記述する 4 つのファイルは同じパスとファイル名を持つ必要があると規定されています。
app.json
ルート ディレクトリにあるこのファイルは、プログラム エントリ ファイルです。
このファイルがないと、WeChat フレームワークはこれを構成ファイルのエントリおよびミニ プログラム全体のグローバル構成として使用するため、プロジェクトを実行できません。ページ登録、ネットワーク設定、ミニプログラムのウィンドウ背景色などを含みます。
app.js
このファイルが必要です。そうでないとエラーが報告されます。ただし、このファイルを作成するだけで、今後はこのファイルでミニ プログラムのライフサイクル関数を監視および処理し、グローバル変数を宣言できます。
app.wxss
グローバルに設定されたスタイル ファイル。プロジェクトには必要ありません。
ミニ プログラムの基本的なファイル構造を理解したら、公式デモの学習を開始できます。調査中にわからないことがあれば、公式ドキュメントを参照してください。発生する可能性が高い問題は次のとおりです -
よくある質問 rpx (レスポンシブ ピクセル)
WeChat アプレットは、異なる解像度の画面に適応できるサイズ単位を新たに定義し、画面幅が 750 rpx であると規定しています。たとえば、iPhone6 では、画面幅が 375px で、合計 750 物理ピクセルがある場合、750rpx = 375px = 750 物理ピクセル、1rpx = 0.5px = 1 物理ピクセルとなります。
(rpx は WeChat で新たに定義されたサイズ単位ではありません。以前からモバイル開発で使用されていました。WeChat は多くのファミリーの長所を吸収し、前任者に基づいて小さなプログラム開発フレームワークを定義しました。Apple と同様、Apple Objective-CはAppStoreがオープンしたときにアプリ開発言語として使用されましたが、OCはAppleによって発明されたものではありません)
このプロジェクトではrpxサイズ単位を使用しましたが、そのプロセス中に非常に奇妙な問題に遭遇しました。隣り合う情報の間に直接分割線を入れますが、個別の分割線が無い場合は、下の図
のように表示されません。 1 行目と 2 行目には実際の線が直接存在しないことを確認してください。ただし、分割線の属性は同じであり、分割線は異なる携帯電話 (異なる解像度) では表示されないことが示されています。解像度によっては複数の分割が表示されない場合もあります。これがシミュレーターのバグなのか rpx のバグなのかはわかりません。最後に、分割線の高さサイズの単位をpxにすることで、この問題が解決されます。 (レイアウトには rpx を使用し、装飾スタイルには px を使用するとよいでしょう。実際には検証されていません。)
40013 エラー
WeChat アプレットが最初に登場したとき、AppID を入力してこの情報を要求すると、それは意味します。クラックされていませんが、公式ソフトウェア アップデートを選択できるようになりました。以下に示すように、AppID なしの開発を選択すると、No AppID を選択することでこのエラーを解決できます。公式の開発ツールをインストールすることをお勧めします。ダウンロードリンクはここにあります。
(現在は個人開発者もミニプログラムに申請でき、appId はもう希少ではないので、そのようなトラブルはありません)
-4058 エラー (app.json ファイルがありません)
WeChat ミニプログラムのプロジェクトを作成するときに、 AppID はありません。プロジェクトの作成時に表示されます。 app.json と app.josn は、プログラムの起動に最も重要なファイルです。プログラムのページ登録、ウィンドウ設定、タブ設定、ネットワーク要求時間の設定はすべてこのファイルの下にあります。作成したプロジェクト ディレクトリに app.json ファイルが存在しない場合、次のエラーが報告されます。
上記のエラー メッセージには、数字 -4058 があることがわかります。これは、WeChat アプレットに最初にアクセスしたときに発生する最も一般的なエラーです。通常、その背後にファイルが存在しないことが原因です。このファイルが存在するかどうかを確認するには、パスを確認します。このエラーの原因は通常、プロジェクトを作成するために選択したディレクトリが間違っているか、存在しないページが app.json に登録されていることが考えられます。
もちろん、app.json ファイルのページに登録されているページが作成されない、またはページを削除しても登録をキャンセルしないという状況もあり、これも -4058 エラーの原因となります。
ページ登録エラー
このエラーはわかりやすいかもしれません、ページ登録エラーです。ページは、Page オブジェクトを通じてレンダリングされます。各ページに対応する js ファイルでページを作成する必要があります。最も簡単な方法は、ページ レンダリングのライフ サイクルをページ内で管理することです。データ処理とイベントはすべてここで完了します。このエラーの原因は通常、ページが作成されたばかりで、js ファイルが処理されていないか、忘れられていることが原因です。したがって、ページを作成するときは、js ファイルで最初にページを作成する習慣を身につける必要があります。
ページ ルート エラー
これは文字通り、ページ ルーティング エラーを意味します。WeChat には 2 つのルーティング方法があります。1 つは wxml ファイル内のコンポーネントを使用する方法で、もう 1 つは wx.navigateTo を呼び出す方法です。
次のコード -
Search
js:
bindtap:function(e){ wx.navigateTo({ url:"search/search"}) }
このように書くと、上記のエラーが表示されます。これは、ルーティングを繰り返し呼び出すことによって発生します。ルートの削除、コンポーネントの削除、または wx.navigateTo の削除です。上記の考えられるルーティング エラーに加えて、次のコード
Search
に似た状況も発生します。これも許可されていません。これは、ナビゲーター コンポーネントをナビゲーター コンポーネント内にネストできないことを意味します。
現在のページに * ハンドラーがありません。
おそらく、現在のページにこのハンドラーがないことを意味するため、エラーが発生する可能性のある場所 (ページ/メッセージ) が定義されているかどうかも判断できます。実際、このような問題は私たちでもよく起こります。 一部の処理イベントは wxml で定義されていますが、イベント処理メソッドが js ファイルに実装されていない場合、このエラーが発生します。次に、プロンプトに従って、以下に示すようにイベント処理を js ファイルに追加すると、このエラー メッセージは表示されなくなります。
bindtap:function(e){ wx.navigateTo({ url:"search/search"}) },
tabBar 設定が表示されない
tabBar が表示されない原因は数多くあります。このエラーを見つけるには、app.json ファイルに直接アクセスしてください。WeChat ミニ プログラムを学習したばかりの場合に最もよくある間違いは次のとおりです。以下 - —
登録ページは、
"pages":["pages/message/message","pages/contact/contact","pages など、app.json の Pages フィールドにページを書き込むことです。 /dynamic/dynamic","pages/dynamic/music/music","pages/index/index","pages/logs/logs"]
1. 書き方が間違っているためTabBarが表示されません。大文字のBを書きます。小文字にすると、tabBar が表示されなくなります。
2. tabBar リストに pagePath フィールドが書き込まれていないか、pagePath 内のページが登録されていません。
3. tabBar リストの pagePath で指定されたページが登録ページに最初に書き込まれていません。 WeChat アプレットのロジックでは、「pages」の最初のページが最初のページになります。これは、tabBar リストの pagePath で指定されたページが、pages の最初のページではない場合に、プログラムの開始後に表示される最初のページです。 , もちろんTV tabBarはありません。
5. tabBar の数は 2 項目未満、または 5 項目以上であることは、tabBar には少なくとも 2 つの項目、最大 5 つの項目が必要であると明確に規定されています。より大きいか小さい場合、tabBar は表示されません。
navigationBarTitle 表示の問題
音楽をクリックして音楽インターフェイスに入ると、タイトルに最初に WeChatForQQ が表示され、次に音楽が表示されるこのエクスペリエンスは、絶対に受け入れられません。 jsファイル内のページのライフサイクルメソッドに設定されます。
ライフサイクルがわからない場合は、クリックして表示できます
Page({ data:{// text:"这是一个页面"}, onLoad:function(options){// 页面初始化 options为页面跳转所带来的参数}, onReady:function(){// 页面渲染完成//NavigationBarTitle如果此处和json文件都设置,最后展示此处的标题栏wx.setNavigationBarTitle({ title:'音乐'}) }, onShow:function(){// 页面显示}, onHide:function(){// 页面隐藏}, onUnload:function(){// 页面关闭} })
onReadyメソッドに設定タイトルが記述されている、つまりページがレンダリングされ、タイトルが表示されていることがコメントから理解できるはずですonReady の前は json ファイルです (関係がカバーされています。タイトルがサブページの json ファイルに設定されている場合、app.json グローバル設定のタイトルが上書きされます)。 onLoad関数にwx.setNavigationBarTitleを書いているのではないかと思われるかもしれませんが、onLoad実行後にページを描画する際にjsonファイルからタイトルを読み込んでしまい、onLoadで設定したタイトルになってしまうため、この設定は誤りです。ページのレンダリング前に表示され、その後、json ファイルのタイルが表示されます。したがって、ttle を設定する最適な場所は、サブファイルの json ファイルを作成し、そのファイルに書き込むことであることが理解できるはずです。色を変更したい場合は、ファイルに直接追加します。はい、このファイルに記述されたプロパティ値は、app.json で設定された値をオーバーライドします。
{ "navigationBarTitleText":"音乐"}
ウィンドウのタイトルは 3 つの場所に依存します:
1. app.json のアプリタイトル設定
2. ページと同じ名前の json ファイル内のタイトル設定
3. wx.setNavigationBarTitle インターフェースを通じて設定されます
If タイトルが静的で、2 によって設定されます。ウィンドウ自体が動的で、タイトルがスケール ID など、渡されたパラメーターに依存する場合は、1 の NavigationBarTitleText を空に設定してから、js で移動するのが最善です。空の設定はすべてのページに影響することに注意してください。
wx.navigateTo でページを開けません
アプリケーションは同時に 5 ページしか開くことができません。5 ページを開くと、wx.navigateTo は通常どおり新しいページを開くことができなくなります。マルチレベルの対話を避けるか、wx.redirectTo を使用してください。
もっと簡単に言うと、wx.redirectToを使用して、PC Webサイトの先史時代のシングルページWebサイトのような、小さなプログラムのシングルページアプリケーション、シングルページアプリケーションを開発することをお勧めします。
wx.navigateTo5 ページの開封制限について、それを解決するツールや解決策はありますか?
navigateTo は 5 レベルに制限されており、実際にはページ スタック内の要素が 5 つを超えてはいけないと規定されています。ページ スタック内の要素の数が 5 に達すると、それ以上要素を追加できなくなります。ミニ プログラム ページ スタックの詳細については、次の記事を参照してください:
www.ifanr.com/minapp/744601
この記事では解決策は提供されません。コーダーは理論的な解決策をここに示します:
1、すべてのジャンプに redirectTo を使用し、js でのみ使用します。 wxmlで使用する場合は、先にイベントをバインドしてイベント
関数内で使用するという使い方もあります。
2,自已实现一个页面栈,每次跳转之前,先推进这个自定义的页面栈。
3,不使用wx.navigateBack,从自定义页面栈中取出一个页面,redirectTo
这样就实现了无级跳转。小程序官方的机制,适用于简单的、层级不多的场景。使用如上自定义栈,好处还有减少内存占用,因为永远都是redirectTo。
本地资源无法通过 css 获取
background-image:可以使用网络图片,或者 base64,或者使用标签。
页面间数据传递
微信小程序路由(页面跳转)是通过API wx.navigateTo或者wxml中组件实现的,不管哪种实现都会有一个重要的参数就是url,它指定了要跳转的页面,并且页面之间数据传递也是通过url来实现的,这个数据传递有点类似于我们使用的get网络请求,把参数都拼接在要跳转界面地址的后面并以“?”连接。然后将要传入的数据以键和值的形式追加在"?"后面,多个参数直接用"&"符合。如我们点击消息聊天记录,将列表上的数据传到下一个页面,可以这样写。
{{item.title}} {{item.message}} {{item.time}} 0}}">{{item.count}}
而数据接收是在js文件的page里接收的,page生命周期有一个onLoad函数,它就是做一些初始化数据的工作,onLoad函数有一个参数options,我们就可以通过key将数据获取,如下
Page({ data:{// text:"这是一个页面"isHiddenToast:true } onLoad:function(options){// 页面初始化 options为页面跳转所带来的参数console.log(options.title)console.log(options.message) }, onReady:function(){// 页面渲染完成}, onShow:function(){// 页面显示}, onHide:function(){// 页面隐藏}, onUnload:function(){// 页面关闭}, bindtap:function(event){ wx.navigateTo({ url:"/pages/message/search/search"}) }, })
这样就实现了页面间数据传递功能。
另外,听说支付宝也开始搞小程序了,连IDE都很像微信小程序开发工具:
文档页:
从“小程序”这个名字来看,因为“程序”是通用名词,而“小”本身没有独特性,所以任何公司申请“小程序”商标估计都难以获得商标管理局的通过,这也就意味着任何公司都可以做自己的“小程序”平台。
以上が模倣性の高いQQのWeChatアプレットの詳細説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Xianyu の公式 WeChat ミニ プログラムが静かに開始されました。ミニ プログラムでは、プライベート メッセージを投稿して購入者/販売者とコミュニケーションしたり、個人情報や注文を表示したり、商品を検索したりすることができます。プログラム、見てみましょう。 Xianyu WeChat アプレットの名前は何ですか? 回答: Xianyu、アイドル取引、中古品販売、評価、リサイクル。 1. ミニ プログラムでは、アイドル メッセージの投稿、プライベート メッセージを介した購入者/販売者とのコミュニケーション、個人情報と注文の表示、指定された商品の検索などができます。 2. ミニ プログラム ページには、ホームページ、近くに、アイドル投稿、メッセージ投稿、私の投稿 5つの機能; 3. 使用したい場合は、購入する前に WeChat 支払いを有効にする必要があります。

WeChat アプレットが画像アップロード機能を実装 モバイル インターネットの発展に伴い、WeChat アプレットは人々の生活に欠かせないものになりました。 WeChat ミニ プログラムは、豊富なアプリケーション シナリオを提供するだけでなく、画像アップロード機能などの開発者定義の機能もサポートします。この記事では、WeChat アプレットに画像アップロード機能を実装する方法と具体的なコード例を紹介します。 1. 準備作業 コードを書き始める前に、WeChat 開発者ツールをダウンロードしてインストールし、WeChat 開発者として登録する必要があります。同時に、WeChat についても理解する必要があります。

Xianyu の公式 WeChat ミニ プログラムが静かに開始され、アイドルアイテムを簡単に公開および交換できる便利なプラットフォームをユーザーに提供します。ミニ プログラムでは、プライベート メッセージを介して購入者または販売者とコミュニケーションしたり、個人情報や注文を表示したり、欲しい商品を検索したりできます。では、WeChat ミニ プログラムでは Xianyu とはいったい何と呼ばれているのでしょうか? このチュートリアル ガイドで詳しくご紹介しますので、知りたいユーザーは、この記事に従って読み続けてください。 Xianyu WeChat アプレットの名前は何ですか? 回答: Xianyu、アイドル取引、中古品販売、評価、リサイクル。 1. ミニ プログラムでは、アイドル メッセージの投稿、プライベート メッセージを介した購入者/販売者とのコミュニケーション、個人情報と注文の表示、指定された商品の検索などができます。 2. ミニ プログラム ページには、ホームページ、近くに、アイドル投稿、メッセージ投稿、マイ投稿の5つの機能、3.

WeChat ミニ プログラムでドロップダウン メニュー効果を実装するには、特定のコード サンプルが必要です。モバイル インターネットの普及に伴い、WeChat ミニ プログラムはインターネット開発の重要な部分となり、ますます多くの人が注目し始めています。 WeChat ミニ プログラムを使用します。 WeChat ミニ プログラムの開発は、従来の APP 開発よりも簡単かつ迅速ですが、特定の開発スキルを習得する必要もあります。 WeChat ミニ プログラムの開発では、ドロップダウン メニューが一般的な UI コンポーネントであり、より良いユーザー エクスペリエンスを実現します。この記事では、WeChat アプレットにドロップダウン メニュー効果を実装し、実用的な機能を提供する方法を詳しく紹介します。

PHPを使用してWeChatアプレットの中古取引機能を開発するにはどうすればよいですか?人気のモバイル アプリケーション開発プラットフォームとして、WeChat アプレットはますます多くの開発者によって使用されています。 WeChat ミニ プログラムでは、中古取引が一般的な機能要件です。この記事では、PHP を使用して WeChat アプレットの中古取引機能を開発する方法と、具体的なコード例を紹介します。 1. 準備作業 開発を開始する前に、以下の条件が満たされていることを確認する必要があります。ミニ プログラムの AppID の登録やミニ プログラムのバックグラウンドでの設定など、WeChat ミニ プログラムの開発環境がセットアップされていること。

WeChat アプレットを使用してカルーセル スイッチング効果を実現する WeChat アプレットは、シンプルで効率的な開発と使用特性を備えた軽量のアプリケーションです。 WeChat ミニ プログラムでは、カルーセル スイッチング効果を実現することが一般的な要件です。この記事では、WeChat アプレットを使用してカルーセル切り替え効果を実現する方法と、具体的なコード例を紹介します。まず、カルーセル コンポーネントを WeChat アプレットのページ ファイルに追加します。たとえば、<swiper> タグを使用すると、カルーセルの切り替え効果を実現できます。このコンポーネントでは、 b を渡すことができます。

WeChat ミニ プログラムでの画像フィルター効果の実装 ソーシャル メディア アプリケーションの人気に伴い、人々は写真にフィルター効果を適用して、写真の芸術的効果や魅力を高めることがますます好まれています。画像フィルター効果は WeChat ミニ プログラムにも実装でき、より興味深く創造的な写真編集機能をユーザーに提供します。この記事では、WeChat ミニ プログラムに画像フィルター効果を実装する方法を紹介し、具体的なコード例を示します。まず、WeChat アプレットのキャンバス コンポーネントを使用して画像を読み込み、編集する必要があります。 Canvasコンポーネントはページ上で使用できます

WeChat ミニ プログラムで画像回転効果を実装するには、特定のコード サンプルが必要です。WeChat ミニ プログラムは、ユーザーに豊富な機能と優れたユーザー エクスペリエンスを提供する軽量のアプリケーションです。ミニ プログラムでは、開発者はさまざまなコンポーネントと API を使用して、さまざまな効果を実現できます。その中で、画像回転効果は、ミニプログラムに興味と視覚効果を加えることができる一般的なアニメーション効果です。 WeChat ミニ プログラムで画像の回転効果を実現するには、ミニ プログラムが提供するアニメーション API を使用する必要があります。以下は、その方法を示す具体的なコード例です。
