android入门-android内嵌H5页面

本文介绍如何创建一个简单的Android应用,该应用通过WebView组件加载并显示网页内容。包括项目搭建步骤、WebView配置及常见问题解决方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目标打开app能够看到看到目前web端的主页,能够正常浏览即可;

目标基本达成,现在回顾一下知识点,其实比较小白;

流程:新建项目–MainActivity中放入一个WebView–WebView加载主页

新建项目:

  1. 右键左侧空白>new project>android>android application project,如图1
    图1
  2. 键入项目名,由于是简单测试 其他不管>Next如图2
    这里写图片描述

  3. 取消Create custom launcher icon
    前面的勾选(就是懒得指定icon嘛,勾上的话后面还得指定一个icon)>Finish如图3
    这里写图片描述

MainActivity中放入一个WebView

1.修改activity_main.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    tools:context="com.example.uitest2.MainActivity" >

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

</RelativeLayout>
2.WebView加载主页

修改MainActivity.java
最终代码如下

public class MainActivity extends ActionBarActivity {

    private WebView webView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //去掉标题栏方法1 未生效 原因不明 
        //百度出的方法2是在AndroidManifest.xml中配置application结点的 android:theme属性 但是 android:theme="@android:style/Theme.NoTitleBar" 这个写法是比较老旧的,这种方式异动是程序总是崩溃
        //原因,升级后theme是由appcompat_v7管理 所以这里theme应该采用android:theme=@style/Theme.AppCompat.Light.NoActionBar”
//      requestWindowFeature(Window.FEATURE_NO_TITLE); 
        setContentView(R.layout.activity_main);

        webView = (WebView) findViewById(R.id.webView);

      //覆盖WebView默认使用第三方或系统默认浏览器打开网页的行为,使网页用WebView打开  
        webView.setWebViewClient(new WebViewClient(){
            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                view.loadUrl(url);
                return true;
            }
        });

        webView.loadUrl("http://www.qq.com//");
    }

}
3.修改功能清单文件
在application节点前加入联网权限的声明:
<!--     联网权限 -->
    <uses-permission android:name="android.permission.INTERNET"></uses-permission>
4.修改application结点的android:theme属性,去掉activity的头
android:theme="@style/Theme.AppCompat.Light.NoActionBar"

至此我们的基本功能都做完了,右键项目run as > android application 即可看到效果

遇见的问题

 - 提示网页无法打开,因为net::ERR_CACHE_MISS

  这是因为没有声明联网权限的缘故,很好解决,
  修改功能清单文件
在application节点前加入联网权限的声明:
<!--     联网权限 -->
    <uses-permission android:name="android.permission.INTERNET"></uses-permission>
 - activity有个很丑的title之类的头部
如何去掉Activity的标题
百度的时候大家都会提到三种方法
1是在setContentView之前加上requestWindowFeature(Window.FEATURE_NO_TITLE); 但我这里并没有用
2是在AndroidManifest.xml中配置application结点的 android:theme属性 但是 android:theme="@android:style/Theme.NoTitleBar" 这个写法是比较老旧的,这种方式异动是程序总是崩溃,原因,升级后theme是由appcompat_v7管理 所以这里theme应该采用android:theme=@style/Theme.AppCompat.Light.NoActionBar”
所以最终的解决方案是
修改application结点的android:theme属性,去掉activity的头
android:theme="@style/Theme.AppCompat.Light.NoActionBar"
 - 点击WebView的链接,默认通过自带的浏览器打开页面
//覆盖WebView默认使用第三方或系统默认浏览器打开网页的行为,使网页用WebView打开  
        webView.setWebViewClient(new WebViewClient(){
            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                view.loadUrl(url);
                return true;
            }
        });

背景:

最近公司接了个外包项目,需要android,但是预算并不多,要求也很低,基本属于有就可以的地步;并且微信端已经在进行中了,等于说有现成的h5.所以,如果做一个简单嵌套H5的App的话成本是最低的.
我之前学过一些android基础,只限于基础,现在正好尝试一下,如果可以的话就我就自己负责android了.

Android应用开发中,内嵌HTML5页面通常是指将Web内容作为Activity的一部分展示给用户。这种做法利用了WebView组件,它是一个可以显示网页内容的视图。以下是创建和使用H5页面的基本步骤: 1. **引入依赖**:在AndroidManifest.xml文件中添加权限,并确保已导入`<uses-permission android:name="android.permission.INTERNET" />`以允许访问网络。 ```xml <uses-permission android:name="android.permission.INTERNET" /> <activity ... <intent-filter> <action android:name="android.intent.action.VIEW" /> <category android:name="android.intent.category.DEFAULT" /> <category android:name="android.intent.category.BROWSABLE" /> <data android:scheme="http" /> <data android:host="yourdomain.com" /> </intent-filter> </activity> ``` 2. **在布局文件中添加WebView**:在XML布局文件中添加WebView控件,例如放在`<FrameLayout>`里。 ```xml <WebView android:id="@+id/webView" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_gravity="center_horizontal" /> ``` 3. **初始化并加载H5**:在Activity中获取WebView实例,设置其属性,然后加载URL。 ```java WebView webView = findViewById(R.id.webView); webView.loadUrl("https://www.example.com/index.html"); webView.setWebViewClient(new WebViewClient()); webView.getSettings().setJavaScriptEnabled(true); // 允许运行JavaScript ``` 4. **处理交互**:如果需要,你可以通过监听WebView的各种事件(如 onPageFinished()、onLoadResource() 等),以及JavaScript Bridge技术与H5页面进行通信。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值