11.1--WebView 的用法

有时候我们可能会碰到一些比较特殊的需求,比如说要求在应用程序里展示一些网页。相信每个人都知道,加载和显示网页通常都是浏览器的任务,但是需求里又明确指出,不允许打开系统浏览器,而我们当然也不可能自己去编写一个浏览器出来,这时应该怎么办呢?

不用担心,Android 早就已经考虑到了这种需求,并提供了一个 WebView 控件,借助它我们就可以在自己的应用程序里嵌入一个浏览器,从而非常轻松地展示各种各样的网页

Webview 的用法也是相当简单,下面我们就通过一个例子来学习ー下吧。新建一个 WebviewTest 项目,然后修改 activity_main.xml 中的代码,如下所示:

<?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:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <WebView
        android:id="@+id/webView"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        />

</LinearLayout>

可以看到,我们在布局文件中使用到了一个新的控件:Webview。这个控件当然也就是用来显示网页的了,这里的写法很简单,给它设置了一个 jd,并让它充满整个屏幕。

然后修改 MainActivity 中的代码,如下所示:

class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        webView.settings.javaScriptEnabled = true
        webView.webViewClient = WebViewClient()
        webView.loadUrl("https://www.baidu.com")
    }
}

MainActivity 中的代码也很短,首先使用 find Viewbyid() 方法获取到了 WebView 的实例,然后调用 Webview 的 getsettings() 方法可以去设置一些浏览器的属性,这里我们并不去设置过多的属性,只是调用了 setjavascriptenabled() 方法来让 Webview 支持 Javascript 脚本。

接下来是非常重要的一个部分,我们调用了 WebView 的 setWebViewClient() 方法,并传入了一个 WebViewClient 的实例。这段代码的作用是,当需要从一个网页跳转到另ー个网页时我们希望目标网页仍然在当前 WebView 中显示,而不是打开系统浏览器。

最后一步就非常简单了,调用 WebView 的 loadUrl()方法,并将网址传入,即可展示相应网页的内容,这里就让我们看一看百度的首页长什么样吧。

另外还需要注意,由于本程序使用到了网络功能,而访问网络是需要声明权限的,因此我们 还得修改 Androidmanifest. Xml 文件,并加人权限声明,如下所示:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.webviewtest">
    <uses-permission android:name="android.permission.INTERNET"/>
    ...
</manifest>

在开始运行之前,首先需要保证你的手机或模拟器是联网的,如果你使用的是模拟器,只需保证电脑能正常上网即可。然后就可以运行一下程序了,效果如图:

可以看到,WebViewTest 这个程序现在已经具备了一个简易浏览器的功能,不仅成功将百度的首页展示了出来,还可以通过点击链接浏览更多的网页。

当然,WebvVew 还有很多更加高级的使用技巧,我们就不再继续进行探讨了,因为那不是本章的重点。这里先介绍了一下 WebView 的用法,只是希望你能对 HTTP 协议的使用有一个最基本的认识,接下来我们就要利用这个协议来做一些真正的网络开发工作了。

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值