小程式支持打開移動應用到底是怎麼回事?

来源:https://www.cnblogs.com/zhanggui/archive/2018/01/27/8365169.html
-Advertisement-
Play Games

小程式支持打開移動應用到底是怎麼回事?什麼APP都可以打開麽? ...


前言

從蘋果官方微信號微信公共平臺發佈的文章《小程式支持打開移動應用》來看,小程式新增了兩個功能:

  1. 支持打開移動應用
  2. 標題欄區域開放自定義

針對第二個功能,就是開發者可以自定義小程式菜單欄的顏色風格,根據需求,對小程式菜單外的標題區域進行自定義,比如設置標題區域的顏色。這裡主要介紹一下支持打開移動應用的功能。

支持打開移動應用

乍一看其實有點標題黨的行為,支持打開移動應用?
讓我想到的是我可以用小程式打開任何移動應用?(答案是不能)
那我是不是可以打開自己的App?(答案是有限制性地打開)
是不是可以打開系統自帶的瀏覽器?(答案是不能)
是不是可以打開第三方的移動應用呢?(答案也是不能)

其實,小程式打開移動應用有一條硬性要求:從移動應用分享至小程式的頁面,用戶訪問時支持打開來源應用。接下來進一步解讀一下這條要求。

大部分程式都有微信分享功能,我們常做的就是將一個圖片、一段文字亦或是一個URL鏈接進行分享,可以分享給好友(包括群)、朋友圈或者是添加到個人收藏,如下:
微信分享
我們還可以分享小程式,如圖:
小程式分享
上面是一個搶票軟體(智行)分享到微信的一個小程式,好友可以點擊小程式幫忙加速。按照官方文章的說法,分享到微信的小程式裡面如果有一個按鈕,實現如下:

<button open-type="launchApp" app-parameter="wechat" binderror="launchAppError">打開APP</button>

那麼當點擊此按鈕時,就會打開源App。在其他情況下是無法打開的,這裡給出了一張能否打開移動APP的圖解:
launch-app
這裡小程式給出一個場景值概念,只有場景值為1036(還有個狀態值true或false,它決定是否能夠打開APP。場景值為1036,狀態值為true)的小程式,才能夠打開源APP,即小程式不能打開任何App,只能跳回分享小程式卡片的APP。官方文檔也對這個標識做瞭解釋:

在小程式的生命周期內,這個狀態的初始值為 false,之後會隨著小程式的每次打開(無論是啟動還是切到前臺)而改變:
1.當小程式從 1036(App 分享消息卡片) 打開時,該狀態置為 true。
2.當小程式從 1089(微信聊天主界面下拉)或 1090(長按小程式右上角菜單喚出最近使用歷史)的場景打開時,該狀態不變,即保持上一次打開小程式時該狀態的值。
3.當小程式從非 1036/1089/1090 的場景打開,該狀態置為 false。

針對第二條,1089和1090那個,我的理解是小程式類似於移動APP,它並沒有關閉,而是在後臺,所以1089和1090打開小程式只是把小程式喚到前臺,所以小程式狀態不變。狀態如果為true,也可以打開移動APP。
以上便是對小程式打開移動應用的介紹,接下來看一下具體代碼實現。

代碼實現分享小程式打開移動應用(iOS版本,Android類似)

首先要做的就是新建一個工程,然後集成微信分享,具體如何集成可以參見官網集成文檔,集成之後,在頁面添加一個按鈕,觸發實現如下:

- (IBAction)openSmallProgramAction:(id)sender {
    //分享小程式的實現
    WXMiniProgramObject *wxMiniObject = [WXMiniProgramObject object];
    wxMiniObject.userName = @"gh_*************";
    wxMiniObject.path = @"pages/index/index";
    //
    WXMediaMessage *message = [WXMediaMessage message];
    message.title = @"我是小程式";
    message.description = @"我是用來測試打開App的小程式";
    message.mediaObject = wxMiniObject;
    
    SendMessageToWXReq *req = [[SendMessageToWXReq alloc] init];
    req.message = message;
    req.scene = WXSceneSession;
    [WXApi sendReq:req];
   //原來做分享的實現
//    SendMessageToWXReq *req = [[SendMessageToWXReq alloc] init];
//    req.text = @"分享的內容";
//    req.bText = YES;
//    req.scene = WXSceneSession;
//    [WXApi sendReq:req];
}

這裡是所有的App都可以用上面的實現方式分享小程式麽嗎?答案是否定的。看官方文檔的說法:

移動應用分享功能支持小程式類型分享,要求發起分享的APP與小程式屬於同一微信開放平臺帳號。支持分享小程式類型消息至好友會話,不支持“分享至朋友圈”及“收藏”。

也就是說小程式分享是有限制的:

  1. 發起分享的App與小程式屬於同一微信開放平臺賬號
  2. 只支持分享小程式類型消息至好友會話(SendMessageToWXReq的scence只支持WXSceneSession)

經過測試,一個賬號不能同時註冊微信開放平臺微信公眾平臺。也就是說:如果你的賬號註冊了微信開放平臺,那麼該賬號就不能再次註冊微信公眾平臺。

微信開放平臺放的是移動APP。
微信公眾平臺放的是小程式。

那官方所說的屬於同一微信開放平臺賬號就不是一個賬號下既有APP又有小程式(因為小程式是在微信公眾平臺開發的)。打開微信開放平臺頁面之後,第一條就好理解了:
移動應用
小程式
如果你想要在移動APP內分享小程式,你必須在該APP所在的微信開放平臺賬號下綁定微信小程式,這樣才可以在APP中實現小程式分享。這就是官方所說的APP和小程式屬於同一微信開放平臺賬號。
那麼APP怎麼知道分享哪個小程式的? 或者說APP是怎麼和小程式關聯的呢?
這就要看上面的那段代碼(前提是你把小程式和APP放到了同一開放平臺賬號下),其中有一行:

wxMiniObject.userName = @"gh_*************";

該userName就是小程式的userName,你可以登錄微信公眾號平臺|小程式,然後在設置--->基本設置中查看,裡面有個原始id,就是小程式的userName。
這樣你就將APP的分享和小程式關聯起來了。
還有一個問題:分享的小程式如何打開指定的頁面呢?
這就要看另一行代碼:

wxMiniObject.path = @"pages/index/index";

你需要設置一下小程式的path,這個path的頁面就是你點擊分享的小程式打開的頁面。這裡看一張小程式開發工具的圖:
小程式代碼段
pages所指的就是頁面,例如上圖的pages文件夾包含了detail和index和logs三個頁面,其中:
index:指代的是信用卡列表頁。
detail:指代的是點擊列表某個item進入的詳情頁。
logs:日誌頁面
所以如果你想跳轉到詳情頁,那麼你在設置wxMiniObject的path時就應該寫成“pages/detail/detail”。這樣就實現了點擊分享的小程式進入指定的頁面了(如果頁面需要參數你也要在分享時傳過去)。

wxml:相當於html
wxss:相當於css
這裡其實是微信小程式自己定義了尾碼。

這個時候你分享的小程式場景值為1036,且狀態為true,如果此時你小程式裡面有open-type為“launchApp”的button,點擊button你就會跳回你的移動APP啦。如果想給APP回傳內容,可以設置app-parameter。就像這個小按鈕:

<button open-type="launchApp" app-parameter="wechat" binderror="launchAppError">打開APP</button>

到此,我想你應該大概瞭解小程式支持打開移動應用到底是怎麼回事了。

總結

小程式並不是支持打開所有移動APP,就算是同一個微信開放平臺賬號下麵的移動APP和小程式,小程式也不一定可以打開,具體還要看場景。

展望

小程式支持跳轉移動APP是很大的進步,在小程式以後的進一步完善中,它應該會朝著APP直接打開小程式方向邁進,而不僅僅是通過分享打開小程式。未來我們也許會實現點擊移動APP裡面的某個按鈕直接打開某個小程式,然後在小程式操作完成之後再次返回到移動APP。(例如微信支付,可以從移動APP跳轉到小程式進行微信支付,支付成功後直接返回移動APP)

附參考

1.小程式支持打開移動應用
2.launchApp(OBJECT)

轉載請註明出處:http://www.cnblogs.com/zhanggui/p/8365169.html


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 下載二進位安裝包 新建mysql用戶和組 解壓二進位安裝包至/usr/local 創建軟鏈接 設置目錄屬主屬組 配置系統環境變數 將存放數據的邏輯捲掛載到/data/mysqldb 設置資料庫文件夾屬主屬組許可權 建立資料庫文件 拷貝示例配置文件 修改my.cnf配置文件 啟動腳本 安全初始化 測試登 ...
  • 回顧 在MySQL的眾多存儲引擎中,只有InnoDB支持事務,所有這裡說的事務隔離級別指的是InnoDB下的事務隔離級別。 讀未提交:一個事務可以讀取到另一個事務未提交的修改。這會帶來臟讀、幻讀、不可重覆讀問題。(基本沒用) 讀已提交:一個事務只能讀取另一個事務已經提交的修改。其避免了臟讀,但仍然存 ...
  • SQL語句系列 1、SQL語句之行操作 2、SQL語句之表操作 3、SQL語句之資料庫操作 4、SQL語句之用戶管理 關係型資料庫的存儲形式 在關係型資料庫中,數據都是以類似於Excel表格的形式存儲(如下圖),我們將“列名”稱作“欄位”,一條數據指一行存儲的信息,對這一行的數據主要的操作有“增、刪 ...
  • 優點 1. 運行速度:對於很簡單的sql,存儲過程沒有什麼優勢。對於複雜的業務邏輯,因為在存儲過程創建的時候,資料庫已經對其進行了一次解析和優化。存儲過程一旦執行,在記憶體中就會保留一份這個存儲過程,這樣下次再執行同樣的存儲過程時,可以從記憶體中直接調用,所以執行速度會比普通sql快。 2. 減少網路傳 ...
  • select count(*) '總欄位數', ISNULL(ISNULL(sum(case when isnullable=0 then 1 end),null),null) as '非空欄位數' from syscolumns where id=object_id( 'EmpInfo') --空 ...
  • 原文地址: "一個輕量級的Android資料庫操作工具" 寫了一個輕量級的Android操作資料庫的ORM工具。方便Android定義資料庫,操作資料庫(增刪改查),資料庫更新,實現了Android對象與資料庫對象之間的映射。源碼地址: "輕量級Android操作資料庫ORM工具" 。可以直接gra ...
  • 1.把要導入成Mudle的項目修改成符合Library的格式 修改該項目中bulid.gradle文件中第一行代碼 把 修改為 然後,修改AndroidManifiest.xml文件中配置信息,此處主要是把原來配置的項目Style等配置以及MainActivity配置刪除,這樣處理是為了防止重覆。以 ...
  • Gradle是一個基於Apache Ant和Apache Maven概念的 項目自動化構建工具 。 它使用一種基於Groovy的特定領域語言(DSL)來聲明項目配置,真正起作用的是Plugin,Gradle預設提供了許多常用的Plugin,如構建Java項目的Plugin、War、Ear等。 Gra ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...