webview的loaddata方法加载html不能正常解析width:100%的问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了webview的loaddata方法加载html不能正常解析width:100%的问题相关的知识,希望对你有一定的参考价值。

"<table style = 'width:100%; text-align:left;font-family:verdana;font-size:8pt;border-collapse:collapse;'>"
为什么我只要加上 style = 'width:100%;就解析不出来呢?
style='width=300;就能正常解析
android编程

参考技术A loadData()中的html data中不能包含'#', '%', '\', '?'四中特殊字符,出现这种字符就会出现解析错误,显示找不到网页还有部分html代码。需要如何处理呢?我们需要用UrlEncoder编码为%23, %25, %27, %3f 。
可以使用以下两种代码,data为string类型的html代码
1 webView.loadData(URLEncoder.encode(data, "utf-8"), "text/html", "utf-8");
这样一些背景效果什么的都不怎么好看了。不推荐。
2 webView.loadDataWithBaseURL(null,data, "text/html", "utf-8", null);
这样就会完美解析了。
参考技术B 请问您是打开特定的网站卡巴才会提示呢,还是说打开所有的网站卡巴都会提示?

如果是特定的网站,说明那个网站的那个页面被绑了这个“下载者木马”,您只需在卡巴提示的时候勾选“应用到所有”然后点拒绝即可。为保险起见,您可以选择升级卡巴至最新病毒库后,断网查杀“关键区域”一次。

如果是所有的网站都提示,那么建议您升级卡巴至最新病毒库后,断网全盘查杀一次。

另:如果您以后在遭遇了这些问题,希望您能用sreng2或者hijackthis的安全工具扫描份您机器的日志发上来,以便大家帮忙准确分析^_^

希望我的回答能对您有所帮助。

Android开发基础之控件WebView

       

WebView可以实现如下功能:

  • 加载本地assets文件夹下的html文件
    wedview.loadUrl(“file:///android_asset/test.html”);
  • 加载网络URL
    webview.loadUrl(“http://m.baidu.com”);
  • 直接加载HTML代码
    方法一:webview.loadData();
    方法二:webview.loadDataWithBaseURL(); // 方法二比方法一更不容易出现乱码
  • Native和JavaScript相互调用

       

       

目录


       

       

一、加载本地assets文件夹下的html文件

第一步,在main目录下新建assets目录


弹出对话框,点击Finish

assets目录就建好了:

       

       

第二步,在assets目录下放置要加载的HTML文件

例如下面这个很简单的HTML文件,用记事本写的:

保存为.html格式

一个html文件就写好了:

       

然后拷贝这个html文件到assets目录下:
        复制你的html文件,然后点击assets目录,ctl+v就复制过去了

       

       

第三步,在activity_main.xml里写一个webview控件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_height="match_parent"
    android:layout_width="match_parent"
    android:orientation="vertical">
    <WebView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/wv1">
    </WebView>
</LinearLayout>

       

       

第四步,在MainActivity.java里使用webview控件加载html文件

在MainActivity.java里写上wv1.loadUrl(“file:///android_asset/testHtml.html”);

package com.example.myapplication;

import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.webkit.WebView;


public class MainActivity extends AppCompatActivity 
    private WebView wv1;

    @Override
    protected void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        wv1=findViewById(R.id.wv1);    // 获取控件id
        // 加载html文件,注意是asset不是assets
        wv1.loadUrl("file:///android_asset/testHtml.html");    
    

效果:

       

       

二、加载网络URL

第一步,在AndroidManifest.xml里写上手机联网权限

<uses-permission android:name="android.permission.INTERNET" />

第二步,在activity_main.xml里写一个webview控件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_height="match_parent"
    android:layout_width="match_parent"
    android:orientation="vertical">
    <WebView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/wv1">
    </WebView>
</LinearLayout>

       

第三步,在MainActivity.java里使用webview控件加载URL

在MainActivity.java里写上wv1.loadUrl(“https://m.baidu.com”); 为什么网址不是www.baidu.com呢,因为m代表这是移动端的网址,www是PC端的网址。

package com.example.myapplication;

import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.webkit.WebView;

public class MainActivity extends AppCompatActivity 
    private WebView wv1;

    @Override
    protected void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        wv1=findViewById(R.id.wv1);    // 获取控件id
        // 设置支持JavaScript
        wv1.getSettings().setJavaScriptEnabled(true);
        // 加载网页
        wv1.loadUrl("https://m.baidu.com");
    

效果:

       

       

       

        问题来了,仅仅是上面那样写,当我们在图中的百度搜索框搜索什么的时候,就不会继续在这个webView里显示,而是会跳转到手机浏览器里去显示。

        如何让webView继续显示而不跳转到浏览器里呢?需要在MainActivity.java里重写一些方法:

package com.example.myapplication;

import androidx.appcompat.app.AppCompatActivity;
import android.graphics.Bitmap;
import android.os.Bundle;
import android.view.KeyEvent;
import android.webkit.WebResourceRequest;
import android.webkit.WebView;
import android.webkit.WebViewClient;

public class MainActivity extends AppCompatActivity 
    private WebView wv1;

    @Override
    protected void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        wv1=findViewById(R.id.wv1);    // 获取控件id
        wv1.getSettings().setJavaScriptEnabled(true); // 设置支持JavaScript
        wv1.setWebViewClient(new MyWebViewClient());
        wv1.loadUrl("https://m.baidu.com");  // 加载网页
    

    // 点击界面上的返回键,如果不希望网页关闭,而希望退回网页的上一级,就重写下面这个方法
    @Override
    public boolean onKeyDown(int keyCode, KeyEvent event) 
        if(keyCode==KeyEvent.KEYCODE_BACK && wv1.canGoBack())
            wv1.goBack();
            return true;
        
        return super.onKeyDown(keyCode, event);
    

    // 当网页跳转时,让webView继续显示而不跳转到浏览器里
    class MyWebViewClient extends WebViewClient 
        // 当页面要跳转时,就会调用下面这个方法
        @Override
        public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) 
            // 在当前webView里继续加载网页
            view.loadUrl(request.getUrl().toString());
            return true;
        

        @Override
        public void onPageStarted(WebView view, String url, Bitmap favicon) 
            super.onPageStarted(view, url, favicon);
        

        @Override
        public void onPageFinished(WebView view, String url) 
            super.onPageFinished(view, url);
        
    
    

效果:

点击进一个网页,不会跳到浏览器,仍在webView中显示:

点击返回键,退回到上一个页面:

以上是关于webview的loaddata方法加载html不能正常解析width:100%的问题的主要内容,如果未能解决你的问题,请参考以下文章

WebView 不加载 javascript 代码

是否可以使用loadData()在Android WebView中单独加载Javascript和HTML?

怎么用WebView加载本地html

使用WebView加载HTML代码

使用WebView加载HTML代码

使用WebView加载HTML代码