flutter webview 調(diào)用js

目標(biāo)

  • 實(shí)現(xiàn)flutter 調(diào)用 js
  • Js 返回結(jié)果

項(xiàng)目實(shí)現(xiàn)

call_js_page.dart通過webview_flutter_plus 來加載 index.html荒辕,使用js交互。

index.html

<html>
<head>
</head>
<body>
<h1 id="title">call js</h1>
<script type="text/javascript">
    function fromFlutter(title){
      document.getElementById("title").innerHTML = title;
      sendBack();
    }
    function sendBack() {
       messageHandler.postMessage("Hello from JS");
    }
</script>
</body>
</html>

js塊中有兩個方法

  • fromFlutter:此方法在flutter調(diào)用并傳遞title參數(shù)
  • sendBack:此方法返回數(shù)據(jù)給flutter

call_js_page.dart

class CallJsPage extends StatefulWidget {
  @override
  State<StatefulWidget> createState() {
    return _CallJsPageState();
  }
}

class _CallJsPageState extends State<CallJsPage> {
  WebViewPlusController? _controller;

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text("flutter web call js"),
      ),
      body: WebViewPlus(
        onWebViewCreated: (controller) {
          _controller = controller;
          controller.loadUrl('assets/index.html');
        },
        javascriptMode: JavascriptMode.unrestricted,
        javascriptChannels: {
          JavascriptChannel(
              name: "messageHandler",
              onMessageReceived: (JavascriptMessage message) {
                print(message);
                ScaffoldMessenger.of(context).showSnackBar(SnackBar(
                  content: Text(message.message),
                ));
              })
        },
      ),
      floatingActionButton: FloatingActionButton(
        child: const Icon(Icons.add),
        onPressed: () {
          _controller?.webViewController
              .evaluateJavascript("fromFlutter('from flutter')");
        },
      ),
    );
  }
}
怎樣調(diào)用index.htmlfromFlutter方法

通過_controller?.webViewController.evaluateJavascript 方法

_controller?.webViewController
              .evaluateJavascript("fromFlutter('from flutter')");
怎樣接收index.html頁面的數(shù)據(jù)

通過JavascriptChannel 來接收,注意下name 要一致。

 javascriptChannels: {
          JavascriptChannel(
              name: "messageHandler",
              onMessageReceived: (JavascriptMessage message) {
                print(message);
                ScaffoldMessenger.of(context).showSnackBar(SnackBar(
                  content: Text(message.message),
                ));
              })
        },

效果圖

flutter_web_call_js.gif

源碼

webview_flutter_plus-call-js

參考

https://pub.dev/packages/webview_flutter_plus

https://medium.com/flutter/the-power-of-webviews-in-flutter-a56234b57df2

https://medium.com/flutter-community/js-native-communication-bridge-in-flutter-f94b65913df1

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌瞳脓,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,576評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件澈侠,死亡現(xiàn)場離奇詭異劫侧,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)哨啃,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,515評論 3 399
  • 文/潘曉璐 我一進(jìn)店門烧栋,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人棘催,你說我怎么就攤上這事劲弦。” “怎么了醇坝?”我有些...
    開封第一講書人閱讀 168,017評論 0 360
  • 文/不壞的土叔 我叫張陵邑跪,是天一觀的道長次坡。 經(jīng)常有香客問我,道長画畅,這世上最難降的妖魔是什么砸琅? 我笑而不...
    開封第一講書人閱讀 59,626評論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮轴踱,結(jié)果婚禮上症脂,老公的妹妹穿的比我還像新娘。我一直安慰自己淫僻,他們只是感情好诱篷,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,625評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著雳灵,像睡著了一般棕所。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上悯辙,一...
    開封第一講書人閱讀 52,255評論 1 308
  • 那天琳省,我揣著相機(jī)與錄音,去河邊找鬼躲撰。 笑死针贬,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的拢蛋。 我是一名探鬼主播桦他,決...
    沈念sama閱讀 40,825評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼瓤狐!你這毒婦竟也來了瞬铸?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,729評論 0 276
  • 序言:老撾萬榮一對情侶失蹤础锐,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后荧缘,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體皆警,經(jīng)...
    沈念sama閱讀 46,271評論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,363評論 3 340
  • 正文 我和宋清朗相戀三年截粗,在試婚紗的時候發(fā)現(xiàn)自己被綠了信姓。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,498評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡绸罗,死狀恐怖意推,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情珊蟀,我是刑警寧澤菊值,帶...
    沈念sama閱讀 36,183評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響腻窒,放射性物質(zhì)發(fā)生泄漏昵宇。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,867評論 3 333
  • 文/蒙蒙 一儿子、第九天 我趴在偏房一處隱蔽的房頂上張望瓦哎。 院中可真熱鬧,春花似錦柔逼、人聲如沸蒋譬。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,338評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽犯助。三九已至,卻和暖如春儡毕,著一層夾襖步出監(jiān)牢的瞬間也切,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,458評論 1 272
  • 我被黑心中介騙來泰國打工腰湾, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留雷恃,地道東北人。 一個月前我還...
    沈念sama閱讀 48,906評論 3 376
  • 正文 我出身青樓费坊,卻偏偏與公主長得像倒槐,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子附井,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,507評論 2 359

推薦閱讀更多精彩內(nèi)容