Android WebView使用記錄

来源:https://www.cnblogs.com/lanjiabin/archive/2020/07/02/13223781.html
-Advertisement-
Play Games

前言 最近做一個簡單的應用,使用到了一些WebView的相關知識,這裡做一些總結。 為WebView中的輸入框賦值 讀取WebView控制項中的值 執行WebView中網頁的方法 註入一段js代碼,為一個控制項賦值一個點擊方法 讀取WebView網頁中的表格. 一、為輸入框賦值和取值 首先,載入網頁的方 ...


前言

最近做一個簡單的應用,使用到了一些WebView的相關知識,這裡做一些總結。

  • 為WebView中的輸入框賦值
  • 讀取WebView控制項中的值
  • 執行WebView中網頁的方法
  • 註入一段js代碼,為一個控制項賦值一個點擊方法
  • 讀取WebView網頁中的表格.

一、為輸入框賦值和取值

首先,載入網頁的方法

	//載入初始網頁
    @SuppressLint({"SetJavaScriptEnabled", "AddJavascriptInterface"})
    public void loadWebView() {
        mWebView.loadUrl(INDEX_URL); // INDEX_URL 網頁地址
        WebSettings settings = mWebView.getSettings();
        settings.setJavaScriptEnabled(true); //允許js操作
        /*
        * 加入內部類,內部類為:InJavaScriptLocalObj
        */
        mWebView.addJavascriptInterface(new IndexActivity.InJavaScriptLocalObj(), "java_obj");
        //監聽連接
        mWebView.setWebViewClient(new WebViewClient() {
            @RequiresApi(api = Build.VERSION_CODES.KITKAT)
            @SuppressLint("SetTextI18n")
            @Override
            public void onPageFinished(WebView view, String url) {
              //載入網頁完成後執行
            }
        });
    }

	//內部類
    //接受數據的介面
    public final class InJavaScriptLocalObj {
        @JavascriptInterface
        public void showDescription(String str, String tag) {
            // str 讀取到的數據
            // tag 標記得到的數據 
        }
    }


案例
獲得一個input的值

1.網頁的代碼

<input autofocus="" 
       onblur="return checkValue(this);" 
       onfocus="return holdOldValue(this);" 
       type="text" 
       id="system_capacity" 
       name="system_capacity" 
       value="4" 
       class="input" 
       title="Allowable Range: 0.05 to 500,000" 
       valtype="num" 
       minval="0.05"
       maxval="500000" 
       displayname="DC System Size"
       oldvalue="4">

2.執行方法

由上面得知,input控制項的id為 system_capacity
所以這樣來得到這個數據
<input> <select> 是一樣的操作,取值和賦值都一樣,<span> 則稍微有不同,主要是全部js操作,熟悉js操作就可以。

 		//獲得 system_capacity 值 <input> <select> 標簽的值
        mWebView.loadUrl("javascript:window.java_obj.showDescription("
                + "document.getElementById('system_capacity').value"
                + ",\'system_capacity\'" +
                ");");

 		//獲得 maindesc 值 <span> 標簽的值
                mWebView.loadUrl("javascript:window.java_obj.showDescription("
                        + "document.getElementById('maindesc').innerHTML"
                        + ",\'maindesc\'" +
                        ");");

3.接收這個值

	//內部類
    //接受數據的介面
    public final class InJavaScriptLocalObj {
        @JavascriptInterface
        public void showDescription(String str, String tag) {
            // str 讀取到的數據
            // tag 標記得到的數據 
            if(str.equals("system_capacity")){
                 Log.v("lanjiabin", "value=" + str + "  tag= " + tag);
            }
        }
    }

4.賦值

為一個輸入框賦值,那就很簡單了
執行方法:

String strJS = String.format("javascript:document.getElementById('system_capacity').value='%s';", city);
mWebView.evaluateJavascript(strJS, null); // null 這裡傳監聽方法

system_capacity是input的id,city是要傳進來的值,就是要賦值給input輸入框的值

二、執行網頁中的方法

//執行一個控制項id為"go"的click方法
String js = String.format("javascript:document.getElementById('go').click();"); 

//執行一個原網頁中的" appNav('systeminfo', 'right') "方法
 String fo = String.format("javascript:appNav('systeminfo', 'right');"); 

mWebView.evaluateJavascript(js, null); // null 這裡傳監聽方法

三、註入一個js,為控制項增加點擊事件

比如這一段網頁代碼

<input autofocus="" 
       onblur="return checkValue(this);" 
       onfocus="return holdOldValue(this);" 
       type="text" 
       id="system_capacity" 
       name="system_capacity" 
       value="4" 
       class="input" 
       title="Allowable Range: 0.05 to 500,000" 
       valtype="num" 
       minval="0.05"
       maxval="500000" 
       displayname="DC System Size"
       oldvalue="4">

onblur="return checkValue(this);" 是input輸入框失去焦點後執行的方法,以此來執行一個驗證數據的方法,我們android不應該直接用手操作網頁來失去焦點和得到焦點,那應該如何來執行這個方法呢?
剛開始的時候,我的確是這樣的做的,也有效,就是通過代碼來失去焦點和得到焦點。
看看這個方法:

//得到焦點
// 1.mWebView得到焦點
mWebView.requestFocus();  

// 2.網頁input輸入框得到焦點
String js1 = String.format("javascript:document.getElementById('system_capacity').focus();"); 

// 3. ....進行為input賦值操作

// 4.input失去焦點
String js2 = String.format("javascript:document.getElementById('system_capacity').blur();");

//執行
mWebView.evaluateJavascript(js1, null);
mWebView.evaluateJavascript(js2, null);

這樣就經歷了一個得到焦點,失去焦點的過程,方法onblur="return checkValue(this);"也順利執行了,但這這樣顯得太過突兀了,又要顯示網頁,又到得到焦點和失去焦點。


我們應該轉變思路:
我們應該把這個方法抽出來,添加為input的onclick方法,然後再執行就可以了。
首先,註入js來添加onclick方法:

//把onblur中的方法轉變為onclick方法。註入js
String j1 = "javascript:document.getElementById('system_capacity').onclick=function(){checkValue(this)};";

//然後執行這個onclick方法,就可以執行了驗證數據的方法
String j2 = "javascript:document.getElementById('system_capacity').onclick();";

四、WebView讀取網頁中的表格數據

其實只要熟悉js代碼基本可以做到對這個網頁的完成操作,思路是這樣的:
1.寫一個js讀取表格的代碼函數,也就是一個js函數,返回表格的數據
2.註入這段js代碼到WebView
3.執行這段js代碼,並獲得返回值


js完整的讀取表格的方法:

 function getTableContent(){
        var mytable = document.getElementById("results1");
        var data = new String();
        for(var i=0,rows=mytable.rows.length; i<rows; i++){
            for(var j=0,cells=mytable.rows[i].cells.length; j<cells; j++){
                data = data+"_"+mytable.rows[i].cells[j].innerHTML;
            }
        }
        return data;
    }


代碼中results1為表格的id,我這裡寫實了,也可以通過參數的方式來傳遞表格id,在for迴圈裡面,可以看到,我用"_"來連接每個表格中的數據,也可以換成自己喜歡的符號。


在安卓中的註入並執行

//js代碼
String results1 = "javascript:" + "(function(){ var mytable = document.getElementById(\"results1\");\n" +
                "\n" +
                "        var data = new String();\n" +
                "\n" +
                "        for(var i=0,rows=mytable.rows.length; i<rows; i++){\n" +
                "\n" +
                "            for(var j=0,cells=mytable.rows[i].cells.length; j<cells; j++){\n" +
                "\n" +
                "                data = data+\"_\"+mytable.rows[i].cells[j].innerHTML;\n" +
                "\n" +
                "            }\n" +
                "\n" +
                "        }\n" +
                "\n" +
                "        return data;})()";

//執行方法,並獲得返回值
mWebView.evaluateJavascript(results1, new ValueCallback<String>() {
            @Override
            public void onReceiveValue(String value) {
            // 這裡就可以得到返回的表格數據
            // 數據的格式基本就是 value_value_value 一個個連接起來的    
            // 然後通過字元串截取和正則表達式就可以得到每個數據了    
            }
        }
                            
                            
//正則表達式截取數據
public String[] regPattern(String reg, String value) {
        Pattern pattern = Pattern.compile(reg);
        Matcher matcher = pattern.matcher(value);
        if (matcher.find()) {
            return matcher.group(1).split("_");
        } else {
            return null;
        }
    }
                            
 //延遲2秒執行
new Handler().postDelayed(new Runnable() {
                    public void run() {
                      //執行方法
                    }
                }, 2000);

編程中我們會遇到多少挫折?表放棄,沙漠盡頭必是綠洲。


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

-Advertisement-
Play Games
更多相關文章
  • 一.說明 oracle 的exp/imp命令用於實現對資料庫的導出/導入操作; exp命令用於把數據從遠程資料庫server導出至本地,生成dmp文件; imp命令用於把本地的資料庫dmp文件從本地導入到遠程的Oracle資料庫中。 二.語法 能夠通過在命令行輸入 imp help=y 獲取imp的 ...
  • create directory mydata as '邏輯目錄路徑'; 例如: create directory mydata as '/data/oracle/oradata/mydata'; grant read,write on directory mydata to public sele ...
  • 本文更新於2019-07-27,使用MySQL 5.7,操作系統為Deepin 15.4。 在創建一個n列的複合索引時,實際是創建了n個索引。可利用索引中最左邊的列集來匹配行,這樣的列集稱為最左首碼。 InnoDB表中的記錄會按一定順序存儲。如果有主鍵,則按主鍵順序;如果沒有主鍵但有唯一索引,則按唯 ...
  • 1問題 uuid採用char(32)或char(36)存儲的話,需要占用32或36個位元組。為節省存儲空間,改為binary(16),占用16位元組。對於500W行的表,可節省7.4G的空間。 mybatis中沒有預設的type handler來完成uuid類型<->binary類型的相互轉換,需要自定 ...
  • 一、發送自定義廣播 1.廣播主要分為兩種: 標準廣播和有序廣播 2.發送標準廣播 先定義一個廣播接收器來接收廣播 package com.example.broadcasttest2; import android.content.BroadcastReceiver; import android. ...
  • 有時候編譯android鏡像會用到一些不需要的app和系統服務,咱們測驗將其裁剪出去。 ####1、源碼目錄 build/target/product/* 在此下麵有不少*.mk文件,這一找到相應的app進行規避修改:android diff–gita/target/product/core.mkb ...
  • 修改android studio的logcat列印顏色 Settings → Editor → Color Scheme → Android Logcat 編程中我們會遇到多少挫折?表放棄,沙漠盡頭必是綠洲。 ...
  • 面試形式:電話面試 作為一個開發者,有一個學習的氛圍跟一個交流圈子特別重要,這是一個我的iOS交流群:761407670 進群密碼‘博客’,不管你是小白還是大牛歡迎入駐 ,分享BAT,阿裡面試題、面試經驗,討論技術, 大家一起交流學習成長! 1. 你平時怎麼解決網路請求的依賴關係:當一個介面的請求需 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...