Android和JS的簡單互動

來源:互聯網
上載者:User

先來看下Web App Hybrid App Native App的圖形解析
Web App

Web App指採用Html5語言寫出的App,不需要下載安裝,類似於現在所說的輕應用,生存在遊覽器中的應用,基本上可以說是觸屏版的網頁應用。

優點:
(1)、開發成本低
(2)、更新快
(3)、無需通知使用者更新,不需要手動升級
(4)、能夠跨多個平台和終端

缺點:
(1)、臨時性的入口
(2)、無法獲得系統層級的通知,提醒,特效。。
(3)、使用者留存率低
(4)、設計受限諸多
(5)、體驗性差 Hybrid App

Hybrid App指的是半原生半web的混合類app,需要下載安裝,看上去類似Native App,但是有很少的UI Web View,訪問的內容是Web

Hybrid App極力的打造類似於Native APP的體驗,但是受限於技術,網速等。。。 Native App

Native App指的是原生程式,一般依託於作業系統,有很強的互動,是一個完整的app,可拓展行強,需要使用者下載安裝使用

優點:
(1)、打造完美的使用者體驗
(2)、效能穩定
(3)、操作速度快,上手流暢
(4)、訪問本地資源(通訊錄、相簿)
(5)、設計出色的動畫效果,轉場
(6)、擁有系統層級的貼心的通知或者提醒
(7)、使用者留存率高

缺點:
(1)、開發成本高,不同平台有不同的開發語言和介面適配
(2)、維護成本高,(例如一款app,已經更新至V5版本,但是仍然有使用者使用V3,V4版本,需要更多的開發人員維護之前的版本)
(3)、更新緩慢,根據不同的平台,提交–審核–上線等經過的流程較複雜

因為Native App是Web App 和Native App的交叉部分,那麼就相當於繼承了兩個的優點。

三者之間的優缺點比較:

Android於HTML互動

互動的兩種方式:
1、Android調用HTML

2、HTML調用Android

步驟:

1、設定允許執行的JS指令碼

mWebView.getSettings().setJavaScriptEnabled(true);

2、添加通訊介面

mWebView.addJavascriptInterface(mInterface, "app");

3、JS調用Android

mInterface.showName("hello javascript");

4、Android調用JS

mWebView.loadUrl("javascript:showName('"+name+"')");

WebView的三種載入方式:

//開啟本包內assers目錄下的index.html檔案    mWebView.loadUrl("file:///android_asset/index.html");//開啟本地sd卡內的index.html檔案    mWebView.loadUrl("content://com.android.thmlfileprovider/sdcard/index.html");//開啟指定URL的html檔案    mWebView.loadUrl("html://www.baidu.com(也就是地址)");
項目來說明使用:

**首先我們先建立一個Module
布局檔案很簡單:**

<?xml version="1.0" encoding="utf-8"?><LinearLayout    xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:layout_width="match_parent"    android:orientation="vertical"    android:layout_height="match_parent"    tools:context=".MainActivity">    <Button        android:id="@+id/button"        android:text="調用JS"        android:layout_width="match_parent"        android:layout_height="wrap_content"/>    <WebView        android:id="@+id/webView"        android:layout_width="match_parent"        android:layout_height="match_parent"></WebView></LinearLayout>

建立一個assets包,在此包下建立一個html檔案:

<!DOCTYPE html><html lang="en"><head>    <meta charset="utf-8">    <title>HTML5 測試</title><style type="text/css">    .input{        width:98%;        height:38px;    }    .button{        width:60%;    height:20px;    background:#fffeff;    }</style><script type="text/javascript">       //js調用as    function sayhello(){        var name = document.getElementById("textName").value;        app.sayHello(name);    }    //as調用js    function showName(name){        document.getElementById("textName").value = name;    }</script></head><body>    <input id="textName" class="input">    <br/>    <hr>    <button class="button" onclick="sayhello()">say hello</button></body></html>

然後activity活動代碼:

這裡寫代碼片
package com.example.ruolan.hybridapp;import android.content.Context;import android.os.Bundle;import android.support.v7.app.AppCompatActivity;import android.view.View;import android.webkit.JavascriptInterface;import android.webkit.WebView;import android.widget.Button;import android.widget.Toast;public class MainActivity extends AppCompatActivity implements View.OnClickListener {    private WebView mWebView;    private Button mButton;    private WebAPPInterface mInterface;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        mWebView = (WebView) findViewById(R.id.webView);        //開啟本包內assets目錄下的index.html檔案        mWebView.loadUrl("file:///android_asset/index.html");        //1、設定允許執行的JS指令碼        mWebView.getSettings().setJavaScriptEnabled(true);        mInterface = new WebAPPInterface(this);        //2、添加通訊介面        mWebView.addJavascriptInterface(mInterface, "app");        mButton = (Button) findViewById(R.id.button);        mButton.setOnClickListener(this);    }    @Override    public void onClick(View v) {        //js調用as        mInterface.showName("hello javascript");    }    class WebAPPInterface {        public Context mContext;        public WebAPPInterface(Context context) {            this.mContext = context;        }        //js調用as        @JavascriptInterface  //加上這一句話,不然的話在高版本的時候有可能報錯        public void sayHello(String name) {            Toast.makeText(mContext, "name= " + name, Toast.LENGTH_SHORT).show();        }        //as調用js        public void showName(final String name) {            //要在子線程中更新ui,這裡我們使用了runOnUiThread()線程            runOnUiThread(new Runnable() {                @Override                public void run() {                    mWebView.loadUrl("javascript:showName('" + name + "')");                }            });        }    }}

當然了哈,如果是搞android的,那麼我們只要寫好android前端的代碼,對html的調用提供一個封裝好的介面,如果是html端,就會封裝好android調用JS的介面。

好了,我們來上一些效果圖:
剛開始的啟動並執行圖形:

點擊了調用JS按鈕(實現android調用js):

最後點擊say hello按鈕:

當然了,這裡只是一個特別簡單的一個例子,我們可以在我們的介面中來定義或者是寫入更加複雜的代碼,完成我們需要的效果。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.