亚州天堂爱爱,做爱视频国产全过程在线观看,成人试看30分钟免费视频,女人无遮挡裸交性做爰视频网站

? ? ?

微信小程序發展越來越快,Flutter應用開發越來越低效?(微信小程序 flutter)

目前的疑惑

微信小程序發展的越來越快,目前小程序甚至取代了大部分 App 的生態位,公司的坑位不增反降,只能讓原生應用開發兼顧或換崗進行小程序的開發。

以我的實際情況來講,公司應用采用的 Flutter 框架,同樣的功能不可避免的就會存在 Flutter 應用開發和微信小程序開發兼顧的情況,這種重復造輪子的工作非常低效。

為什么會存在這種情況?

隨著 2019 年5月 Google I/O 上 Flutter 1.5.4 的發布,宣示著 Flutter 真正開始進入全終端時代,意味著只需要寫一份代碼,不需要任何額外的修正改,就可以運行在 iOS、Android、Web、PC 上。Flutter 正在革命性的改變移動開發的生態系統,從面向各個終端的開發,轉向面向框架開發,不僅會改變開發者的開發方式,也有越來越多的公司開始關注使用 Flutter。

Flutter 作為一個跨平臺的框架,其開發技術棧融合了 Native 和前端的技術,不僅涉及到了 Native(Android、iOS )的開發知識,又吸取了很多前端(例如 React)的技術理念和框架,并且在此基礎上又有提升,形成 Flutter 自己獨特的技術思維。

微信小程序發展越來越快,Flutter應用開發越來越低效?(微信小程序 flutter)

flutter 框架

但目前來講,Flutter 并不支持小程序,Flutter for Web 雖然最后也會生成 JS 代碼,但是 Flutter 生成的 JS 和 CSS 都是不能修改的。而在 Flutter 中也沒辦法通過 Dart 直接調用小程序的接口,所以現階段用 Flutter 開發小程序不是太好的選擇。

一些解決思路的產生

但是公司和業務也不得不向著互聯網巨頭的流量低頭,同時小程序的逐漸風靡,也使得用戶下載 App 的習慣產生變化,不管購物、訂餐還是辦事都會首先查找“打開即用,即用即走”的小程序可以使用,省去了下載 App 的繁瑣流程。

當然也知道很多開發者對于小程序是有非常多意見的,App 也不會說死就死,畢竟 App 相對于小程序來講,還是有很多優勢。所以 App 和小程序開發都共存的情況下,如何解決效率問題?

能否讓過往開發的小程序直接運行在 Flutter 開發的應用中呢?同樣一個功能業務僅需一次小程序開發,即可實現在除了微信端的其它 App 中也運行起來。

在 Google 找相關的解決方案和資料的時候,發現國外幾乎沒有這種方案,國內倒是有廠商在做這塊,想想也確實符合情理。基于公司 Flutter 框架的基礎現實情況下,名為 FinClip 小程序容器技術的產品是能夠支持除原生 iOS、Android 之外的 Flutter 和 React Native ,并且能夠直接兼容微信小程序語法,于是大概測試了下這個產品。

實操上手過程

原理其實挺簡單的,FinClip 提供了小程序 SDK 給 Flutter 應用進行集成,這樣以來 App 即擁有了一套可運行小程序業務代碼的宿主環境。

微信小程序發展越來越快,Flutter應用開發越來越低效?(微信小程序 flutter)

小程序容器的原理

1、獲取憑據

集成 SDK 需要在 FinClip 平臺中創建應用并綁定小程序,獲得每個應用專屬的 SDK KEY 及 SDK SECRET ,隨后可以在集成 SDK 時填寫對應的參數。打開小程序時 SDK 會自動初始化,并校驗 SDK KEY,SDK SECRET 與BundleID (Application ID) 是否正確。

2、集成插件

在項目 pubspec.yaml 文件中添加依賴。

mop: latest.version

如果電腦是 mac M1 芯片,還需要在 iOS 文件夾的 Podfile 文件增加以下3行代碼

config.build_settings['ENABLE_BITCODE'] = 'NO'config.build_settings['IPHONEOS_DEPLOYMENT_TARGET'] = '9.0'config.build_settings['EXCLUDED_ARCHS[sdk=iphonesimulator*]'] = 'arm64 i386'

示例:

post_install do |installer| installer.pods_project.targets.each do |target| flutter_additional_ios_build_settings(target) target.build_configurations.each do |config| config.build_settings['ENABLE_BITCODE'] = 'NO' config.build_settings['IPHONEOS_DEPLOYMENT_TARGET'] = '9.0' config.build_settings['EXCLUDED_ARCHS[sdk=iphonesimulator*]'] = 'arm64 i386' end endend

3、Flutter API

在集成后,使用 SDK 提供的 API 之前必須要初始化 SDK 。下面我羅列官方的一些必要的 API ,更具體的也可以查閱官方文檔。

1)初始化 sdk 接口

/// /// /// initialize mop miniprogram engine. /// 初始化小程序 /// [sdkkey] is required. it can be getted from api.finclip.com /// [secret] is required. it can be getted from api.finclip.com /// [apiServer] is optional. the mop server address. default is https://mp.finogeek.com /// [apiPrefix] is optional. the mop server prefix. default is /api/v1/mop /// [cryptType] is optional. cryptType, should be MD5/SM /// [disablePermission] is optional. /// [encryptServerData] 是否對服務器數據進行加密,需要服務器支持 /// [userId] 用戶id /// [finStoreConfigs] 多服務配置 /// [uiConfig] UI配置 /// [debug] 設置debug模式,影響調試和日志 /// [customWebViewUserAgent] 設置自定義webview ua /// [appletIntervalUpdateLimit] 設置小程序批量更新周期 /// [maxRunningApplet] 設置最大同時運行小程序個數 /// Future<Map> initialize( String sdkkey, String secret, { String? apiServer, String? apiPrefix, String? cryptType, bool encryptServerData = false, bool disablePermission = false, String? userId, bool debug = false, bool bindAppletWithMainProcess = false, List<FinStoreConfig>? finStoreConfigs, UIConfig? uiConfig, String? customWebViewUserAgent, int? appletIntervalUpdateLimit, int? maxRunningApplet, })

2)打開小程序

/// open the miniprogram [appId] from the mop server. /// 打開小程序 /// [appId] is required. /// [path] is miniprogram open path. example /pages/index/index /// [query] is miniprogram query parameters. example key1=value1&key2=value2 /// [sequence] is miniprogram sequence. example 0,1.2.3,4,5... /// [apiServer] is optional. the mop server address. default is https://mp.finogeek.com /// [apiPrefix] is optional. the mop server prefix. default is /api/v1/mop /// [fingerprint] is optional. the mop sdk fingerprint. is nullable /// [cryptType] is optional. cryptType, should be MD5/SM Future<Map> openApplet( final String appId, { final String? path, final String? query, final int? sequence, final String? apiServer, final String? scene, })

3)獲取當前正在使用的小程序信息

當前小程序信息包括的字段有appId,name,icon,description,version,thumbnail

/// /// get current using applet /// 獲取當前正在使用的小程序信息 /// {appId,name,icon,description,version,thumbnail} /// /// Future<Map<String, dynamic>> currentApplet()

4)關閉當前打開的所有小程序

/// /// close all running applets /// 關閉當前打開的所有小程序 /// Future closeAllApplets()

4、官方示例

官方給了一個實例,我也直接放上來,大家可以參照下。

import 'package:flutter/material.dart';import 'dart:async';import 'dart:io';import 'package:mop/mop.dart';void main() => runApp(MyApp());class MyApp extends StatefulWidget { @override _MyAppState createState() => _MyAppState();}class _MyAppState extends State<MyApp> { @override void initState() { super.initState(); init(); } // Platform messages are asynchronous, so we initialize in an async method. Future<void> init() async { if (Platform.isIOS) { //com.finogeeks.mopExample final res = await Mop.instance.initialize( '22LyZEib0gLTQdU3MUauARlLry7JL/2fRpscC9kpGZQA', // SDK Key '1c11d7252c53e0b6', // SDK Secret apiServer: 'https://api.finclip.com', // 服務器地址 apiPrefix: '/api/v1/mop' // 服務器接口請求路由前綴 ); print(res); } else if (Platform.isAndroid) { //com.finogeeks.mopexample final res = await Mop.instance.initialize( '22LyZEib0gLTQdU3MUauARjmmp6QmYgjGb3uHueys1oA', // SDK Key '98c49f97a031b555', // SDK Secret apiServer: 'https://api.finclip.com', // 服務器地址 apiPrefix: '/api/v1/mop' // 服務器接口請求路由前綴 ); print(res); } if (!mounted) return; } @override Widget build(BuildContext context) { return MaterialApp( home: Scaffold( appBar: AppBar( title: const Text(' FinClip 小程序 Flutter 插件'), ), body: Center( child: Container( padding: EdgeInsets.only( top: 20, ), child: Column( children: <Widget>[ Container( decoration: BoxDecoration( borderRadius: BorderRadius.all(Radius.circular(5)), gradient: LinearGradient( colors: const [Color(0xFF12767e), Color(0xFF0dabb8)], stops: const [0.0, 1.0], begin: Alignment.topCenter, end: Alignment.bottomCenter, ), ), child: FlatButton( onPressed: () { Mop.instance.openApplet('5e3c147a188211000141e9b1'); // 小程序 AppID }, child: Text( '打開示例小程序', style: TextStyle(color: Colors.white), ), ), ), SizedBox(height: 30), Container( decoration: BoxDecoration( borderRadius: BorderRadius.all(Radius.circular(5)), gradient: LinearGradient( colors: const [Color(0xFF12767e), Color(0xFF0dabb8)], stops: const [0.0, 1.0], begin: Alignment.topCenter, end: Alignment.bottomCenter, ), ), child: FlatButton( onPressed: () { Mop.instance.openApplet('5e4d123647edd60001055df1', sequence: 1); // 小程序 AppID }, child: Text( '打開官方小程序', style: TextStyle(color: Colors.white), ), ), ), ], ), ), ), ), ); } }

版權聲明:本文內容由互聯網用戶自發貢獻,該文觀點僅代表作者本人。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。如發現本站有涉嫌抄襲侵權/違法違規的內容, 請發送郵件至 舉報,一經查實,本站將立刻刪除。

(0)
上一篇 2023年4月9日 上午9:13
下一篇 2023年4月9日 上午9:29

相關推薦

  • 漫畫網頁項目管理系統

    漫畫網頁項目管理系統 漫畫網頁項目管理系統是一種高效的工具,可以幫助漫畫網站管理人員更好地管理項目,提高生產效率,降低管理成本。 該系統是一個基于Web的應用程序,提供了一系列的功…

    科研百科 2025年1月1日
    2
  • 科研項目保密管理要求

    科研項目保密管理要求 科研項目的保密管理是確保科研項目 confidential 的重要措施,其重要性不言而喻。保密管理要求是確保科研項目 confidential 的重要措施,其…

    科研百科 2025年3月13日
    0
  • 學校科研項目建設的意義

    學校科研項目建設的意義 在學校科研項目建設中,我們深刻意識到了科技創新對于國家和社會的重要性。隨著時代的變遷,科技已經成為推動社會發展的重要力量。而學校科研項目的建設則是推動科技創…

    科研百科 2025年1月31日
    1
  • 緊扣“六字訣”!三亞黨建新實踐煥發新活力

    “ 海南要堅持和加強黨的全面領導,確保全面深化改革開放正確方向。 ——總書記囑托 ” 一抹黨旗紅,成了這個四月鹿城最溫暖的顏色。3月31日,疫情突襲三亞,全市1.8萬余名黨員迅速下…

    科研百科 2023年2月18日
    251
  • 自動化辦公系統平臺(天津辦公自動化系統)

    天津辦公自動化系統: 提升工作效率的利器 隨著現代辦公自動化系統的不斷普及,天津辦公自動化系統已經成為現代辦公中不可或缺的一部分。天津辦公自動化系統不僅可以提高員工的工作效率,還可…

    科研百科 2024年8月31日
    21
  • 你知道視頻字幕添加工具有哪些嗎?看看三款視頻字幕添加的軟件

    你知道視頻字幕添加工具有哪些嗎?看看三款視頻字幕添加的軟件 當我們在社交媒體上分享自己制作的視頻時,可能會想要為視頻添加字幕。因為這可以讓觀看視頻的小伙伴更好地理解和欣賞我們的視頻…

    科研百科 2024年3月29日
    62
  • 二級建設工程項目管理

    二級建設工程項目管理 二級建設工程項目管理是指由各地建設管理部門或公司管理的較低級別的建設工程項目,其項目規模、施工復雜程度和施工周期一般較長。因此,二級建設工程項目管理需要具有較…

    科研百科 2024年9月16日
    27
  • 打出黨建“組合拳”,聯投湖北路橋獲評國家級優秀成果(聯投湖北路橋領導名單)

    極目新聞記者 黎先才 通訊員 陳慧 陽玲霞 近日,中國施工企業管理協會公布了2024年“工程建設企業黨建工作優秀成果”的名單。極目新聞記者獲悉,聯投湖北路橋京港澳高速公路改擴建工程…

    科研百科 2024年5月31日
    56
  • 項目信息管理系統的優勢

    項目信息管理系統的優勢 項目信息管理系統是一種能夠幫助組織管理項目信息的工具,具有許多優勢。在本文中,我們將討論這些優勢,并介紹如何使用項目信息管理系統來提高項目效率和準確性。 項…

    科研百科 2025年1月21日
    1
  • 醫學科研項目申報類型

    醫學科研項目申報類型 隨著現代醫學的不斷發展,醫學科研項目申報類型也在不斷變化。目前,常見的醫學科研項目申報類型包括: 1. 臨床科研項目:這些項目是為了改進醫療服務和提高臨床實踐…

    科研百科 2025年4月2日
    2