App之webView

访问百度

  1. xml添加一个WebView控件
<WebView 
	android:id="@+id/wb"
	android:layout_width="match_parent"
	android:layout_height="match_parent"
/>
  1. MainActivity,设置控件显示的网页 (网页设置loadUrl)
public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        
        final WebView wb = (WebView) findViewById(R.id.webView1);
        final EditText ed = (EditText) findViewById(R.id.ed);
        
        wb.setWebViewClient(new WebViewClient());
        
        ed.setOnEditorActionListener(new TextView.OnEditorActionListener() {
			
			@Override
			public boolean onEditorAction(TextView arg0, int arg1, KeyEvent event) {
				// TODO Auto-generated method stub
				String str = ed.getText().toString();
				wb.loadUrl(str);
				return (event.getKeyCode() == KeyEvent.KEYCODE_ENTER);
			}
		});
        
    }
    
}

添加APP网络访问权限
在这里插入图片描述

输入网址,访问

  1. 添加一个EditText控件,使用hint属性提示用户输入网址
<EditText 
	android:id="@+id/ed"
	android:layout_width="match_parent"
	android:layout_height="match_parent"
	android:hint="请输入网址"
/> 
  1. EditText回车不换行
ed.setOnEditorActionListener(new TextView.OnEditorActionListener() {
			
	@Override
	public boolean onEditorAction(TextView arg0, int arg1, KeyEvent event) {
		// TODO Auto-generated method stub
		String str = ed.getText().toString();
		wb.loadUrl(str);
		return (event.getKeyCode() == KeyEvent.KEYCODE_ENTER);
	}
});
  1. 拿到输入,然后访问网页
String str = ed.getText().toString();
wb.loadUrl(str);

具体代码如下

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity" >

    <LinearLayout 
        android:id="@+id/ll"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        >
        <EditText 
            android:id="@+id/ed"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:hint="请输入网址"
            />
    </LinearLayout>
    <WebView
        android:id="@+id/webView1"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_below="@id/ll"
		 />

</RelativeLayout>

package com.example.dzz.baidu;

import android.app.Activity;
import android.os.Bundle;
import android.view.KeyEvent;
import android.webkit.WebChromeClient;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.EditText;
import android.widget.TextView;

public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        
        final WebView wb = (WebView) findViewById(R.id.webView1);
        final EditText ed = (EditText) findViewById(R.id.ed);
        
        wb.setWebViewClient(new WebViewClient());
        
        ed.setOnEditorActionListener(new TextView.OnEditorActionListener() {
			
			@Override
			public boolean onEditorAction(TextView arg0, int arg1, KeyEvent event) {
				// TODO Auto-generated method stub
				String str = ed.getText().toString();
				wb.loadUrl(str);
				return (event.getKeyCode() == KeyEvent.KEYCODE_ENTER);
			}
		});
        
    }
    
}

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
App中的WebView是一个嵌入式的浏览器,它是嵌入在原生应用中的浏览器引擎。与传统浏览器不同,WebView只是原生应用的可视化组件,用于展示从服务器获取的内容,而不需要存储在本地。它具有灵活性,可以重用浏览器端的web应用和希望展示在原生应用中的web应用代码。在WebView中运行的JavaScript代码可以调用原生系统的API,没有传统浏览器沙箱的限制。这意味着开发人员可以在WebView中实现与原生应用代码的相互通信,并调用原生API集成系统级功能,如传感器、存储、日历、联系人等。WebView可以用于多种用途,包括作为app内置浏览器、显示广告、承载app内的所有交互等。从部署和更新的角度来看,WebView提供了方便的混合应用开发方式。\[1\] 在使用WebView时,可以采取一些优化方法。一种方法是在客户端刚启动时初始化一个全局的WebView,并隐藏起来。当用户访问WebView时,直接使用这个WebView加载对应网页并展示,这样可以减少WebViewApp中的首次打开时间。然而,这种方法可能会带来额外的内存消耗和内存泄漏的风险。另一种方法是在客户端初始化WebView的同时,由原生应用开始网络请求数据,并在页面初始化完成后向原生应用获取代理请求的数据。这种方法可以并行进行数据请求和WebView初始化,从而缩短总体的页面加载时间。\[3\] 总之,WebView是原生应用中的嵌入式浏览器引擎,可以展示从服务器获取的内容,并具有与原生应用代码的交互能力。在使用WebView时,可以根据需求采取优化方法来提升性能和用户体验。\[1\]\[3\] #### 引用[.reference_title] - *1* [手机app开发可选技术——webview](https://blog.csdn.net/manerzi/article/details/127622731)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [APPWebView性能优化](https://blog.csdn.net/u013372487/article/details/73065729)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值