鸿蒙-webview的使用和JS交互(附源码)【鸿蒙开发04】

日常我们在开发项目时,为了项目快速的开发和迭代,难免会用到H5页面。使用鸿蒙进行项目开发时,也一样免不了要加载H5页面,在移动开发中打开H5页面需要使用WebView组件。同时,为了和H5页面进行数据交换,有时候还需要借助JSBridge来实开发者现客户端与H5之间的通讯android开发教程

那么鸿蒙之中用到的技术是什么呢࿱安卓移动开发f;WebView

在此之前,先看一个报错

App Launch: The Huawei Lite Simulator supports only Lite proje前端开发软件cts.

鸿蒙-webview的使用和JS交互(附源码)【鸿蒙开发04】

这是什么原因呢&java语言#xff0c;android开发其实简单,就是你没有登陆

鸿蒙-webview的使用和JS交互(附源码)【鸿蒙开发04】

所以解决这个的问题就是你重新登录就好了。

鸿蒙-webview的使用和JS交互(附源码)【鸿蒙开发04】

汉化(V3.0 Beta2(2021-12-3javascript百炼成仙1)版本以上支持)

还有一个问题可能就是目前编辑器大家看着不太习惯,需要汉化一下,那么如何汉化呢,结合Androidstudio的android开发工具箱经验,分为如下几步

第一步点击File-setting

鸿蒙-webview的使用和JS交互(附源码)【鸿蒙开发04】

第二步plugins里面选择如图所示的插件,前端开发是干什么的;并安javascript download装。

鸿蒙-webview的使用和JS交互(附源码)【鸿蒙开发04】

第三步,重启,汉android开发板化完成

鸿蒙-webview的使用和JS交互(附源码)【鸿蒙开发04】

第一步创建项目

鸿蒙-webview的使用和JS交互(附源码)【鸿蒙开发04】

点击next

鸿蒙-webview的使用和JS交互(附源码)【鸿蒙开发04】

第二步等依赖安装安装完成

前端开发需要学什么三步打开模拟器

鸿蒙-webview的使用和JS交互(附源码)【鸿蒙开发04】

点击登录,打开浏览器授权

选择p40

鸿蒙-webview的使用和JS交互(附源码)【鸿蒙开发04】

启动模拟器

鸿蒙-webview的使用和JS交互(附源码)【鸿蒙开发04】

第五步开始正文

接下来开javaee始正文。

应用预览:

  1. 点击&#javascript百炼成仙034;打开网址"按钮会加载上方网址的Web页面,通过后退"和&#android开发工具箱034;前进"按钮实现Web页面间的导航。
  2. 点击"加载本地网页"按钮开发者模式怎么关闭加载本地Web页面,点击"发送前端开发工资一般多少消息给本地html"或者Web页面中的"调用Javandroid开发中用的数据库是a方法开发者模式怎么关闭4;按钮,实现应用与移动开发者人数最多的年龄段是Web页面间的交互。

鸿蒙-webview的使用和JS交互(附源码)【鸿蒙开发04】

这里是http访问方式,鸿蒙的默认是https访问模式前端开发需要掌握什么技术,如果您的请求网址是http开头的,可以继续查看后面的教程。

鸿蒙-webview的使用和JS交互(附源码)【鸿蒙开发04】

1. 增加一个WebView组件

步骤 1 - 在"resources/base/layout/ability_main.x开发者模式打开好还是关闭好ml"文件中创建WebView,开发者模式有什么用;前端开发示例代码如下:

<ohos.agp.components.webengine.WebView
    ohos:id="$+id:webview"
    ohos:height="match_parent"
    ohos:width="match_parent">
</WebView>
复制代码

步骤 2 - 在"slice/MainAbilitySlice.java&java面试题#034;文件中通过如下方式获取WebView对象,示例代码如下:

WebView webview = (WebView) findComponentById(ResourceTable.Id_webview);
复制代码

2. 通过WebViewjava编译器加载Web页面

WebView加载页面分为加载Web页面和加载本地Web页面两种情况,接下来我们将分别进行介绍。

1.WebView加载网络Web页面

跟Android类似,要访问网络,我们首先要配置网络访问权限,在config.json的"modulejava面试题"节点最后,添加上网络权限代码

module": {
......
"reqPermissions": [
{
   "name": "ohos.permission.INTERNET"
 }
]
}
复制代码

2 设置访问模式

鸿蒙的默认是https访问模式,如果您的请求网址是http开头的,请在config.jsjavaeeon文件中的deviceConfig下,添java语言加如下设置

"deviceConfig": {
    "default": {
      "network": {
        "cleartextTraffic": true
      }
    }
  },
复制代码

在"slice/Mjava培训ainAbilitySlice.java"文件中通过webview.load(String url)方法访问具体的Web页面,通过WebC移动开发者人数最多的年龄段是onfig类对WebView组件的行为进行配置&java面试题#xff0c;示例代码如下:

WebConfig webConfig = webview.getWebConfig();
// WebView加载URL,其中urlTextField为输入URL的TextField组件
webview.load(urlTextField.getText());
复制代码

在Web页面进行链接跳转时,WebView默认会打开目标网址,通过WebAgent对象可以定制该行为,示例代码如下:

webview.setWebAgent(new WebAgent() {
            @Override
            public boolean isNeedLoadUrl(WebView webView, ResourceRequest request) {
                if (request == null || request.getRequestUrl() == null) {
                    LogUtil.info(TAG,"WebAgent isNeedLoadUrl:request is null.");
                    return false;
                }
                String url = request.getRequestUrl().toString();
                if (url.startsWith("http:") || url.startsWith("https:")) {
                    webView.load(url);
                    return false;
                } else {
                    return super.isNeedLoadUrl(webView, request);
                }
            }
        });
复制代码

除此之外,W开发者选项在哪ebAgent开发者模式怎么关闭对象还提供了相关的回调函数以观测页面状态的变更,如o移动开发是干什么的nLoad开发者模式打开好还是关闭好ingP移动开发主要学什么age、onPageLoaded、onError开发者选项开启好还是关闭好等方法。WebView提供Navigator类进行历史记录的浏览和处理,通过getNavigator()方法获取该类的对象,使用canGoBack()或canG前端开发工资一般多少oForward()方法检查是否可以向后或向前浏览,开发者模式有什么用;使用goBack()或goForward()方法向后或向前浏览,示例java代码如下&#开发者模式有什么用xff1a;

Navigator navigator = webView.getNavigator();
if (navigator.canGoBack()) {
    navigator.goBack();
}
if (navigator.canGoForward()) {
    navigator.goForward();
}
复制代码

3.WebView加载本地Web页面

将本地的HTML文件放在"resources/rawfile/"目录开发者选项打开有害吗下&#android开发xff0c;在本教程中命名为test.html。在HarmonyOS系统中,WebView要访问本地Web文件,需要通过DataAbility的方式进行访问,DataAbility的具体使用方法可以参考开发

DataAbility,关javascript百炼成仙于DataAbility的相关知识,后面也会继续展示&#开发者选项怎么关闭xff0c;谁让他是最重要的内容呢。

在"entry/src/main/config.json"中完成DataAbility的前端开发是干什么的声明,javascript百炼成仙示例代码如下&#javascriptxff1a;java语言

module": {
......
"abilities": [
{
  "name": "com.huawei.codelab.DataAbility",
  "type": "data",
  "uri": "dataability://com.example.harmonyosdemo.DataAbility"
}
]
}
复制代码

另外javascript需要实现一个DataAbility,通过实现openRawFile(Urandroid开发工具箱i uri, String mode)方法,完成WebView对本地Web页面前端开发前景怎么样啊的访问,示例代码如下:

public class DataAbility extends Ability {
    ...
    @Override
    public RawFileDescriptor openRawFile(Uri uri, String mode) throws FileNotFoundException {
        if (uri == null) {;
            return super.openRawFile(uri, mode);
        }
        String path = uri.getEncodedPath();
        int splitIndex = path.indexOf('/', 1);
        String providerName = Uri.decode(path.substring(1, splitIndex));
        String rawFilePath = Uri.decode(path.substring(splitIndex + 1));
        RawFileDescriptor rawFileDescriptor = null;
        try {
            rawFileDescriptor = getResourceManager().getRawFileEntry(rawFilePath).openRawFileDescriptor();
        } catch (IOException e) {
            // 异常处理
        }
        return rawFileDescriptor;
    }
}
复制代码

移动开发票"slice/MainAbilitySlice.java"中声明需要访问的文件路径,通过webview.load(String url)方android开发框架法加载本地Web页面,可以通过WebConfig类的对象对WebView访问DataAbility的能力进行配置,示例代码如下:

private static final String URL_LOCAL = "dataability://com.huawei.codelab.DataAbility/resources/rawfile/test.html";
// 配置是否支持访问DataAbility资源,默认为true
webConfig.setDataAbilityPermit(true);
webview.load(URL_LOCAL);
复制代码

4. 实现应用与WebView中的Web页面间的通信

本教程以本地Web页面"resources/rawfile/tes移动开发主要学什么t.html"为例介绍如何实现应用与WebView中的Web页面间java编译器交互开发者选项怎么设置最流畅。 首先需要对WebConfig进行配置,使能WebView与Web页面JavaScript交互的能力,示例代码如下:

// 配置是否支持JavaScript,默认值为false
webConfig.setJavaScriptPermit(true);
复制代码

1.应用调用Web页面java模拟器

在"前端开发工资一般多少;resources/rawfile/test.html"中编写callJS方法,待应用调用,示例代码如下:

<script type="text/javascript">
// 应用调用Web页面
function callJS(message) {
    alert(message);
}
</script>
复制代码

在"slice/MainAbilit前端开发是干什么的ySlice.java"中实现应用对JavaScript的调用,示例代码如下:

webview.executeJs("javascript:callJS('这是来自JavaSlice的消息')", msg -> {
        // 在这里处理Js的方法的返回值
    });
复制代码

我们可以通过setBrowserAgent方法设置自定义BrowserAgent对象,以观测JavaScript事件及通知等&前端开发软件#xff0c;通过复写onJjava编译器sMessageShow方法来接管Web页面弹出Ale开发者选项开启好还是关闭好rt对开发者模式有什么用话框的事件,示例代码如下:

webview.setBrowserAgent(new BrowserAgent(this) {
            @Override
            public boolean onJsMessageShow(WebView webView, String url, String message, boolean isAlert, JsMessageResult result) {
                LogUtil.info(TAG,"BrowserAgent onJsMessageShow : " + message);
                if (isAlert) {
                    // 将Web页面的alert对话框改为ToastDialog方式提示
                    new ToastDialog(getApplicationContext()).setText(message).setAlignment(LayoutAlignment.CENTER).show();
                    // 对弹框进行确认处理
                    result.confirm();
                    return true;
                } else {
                    return super.onJsMessageShow(webView, url, message, isAlert, result);
                }
            }
        });
复制代码

2.Web页面使用JavaScript调用应用

在"resources/rawfile/test.html"中编写按钮,当按钮被点击时实现JavaScript对应用的调用,示例代码如下:

<body>
<button id="button" onclick="sendData()" style="background-color:#70DBDB;height:30px;">调用Java方法</button>
<script type="text/javascript">
  function sendData() {
      if (window.JsCallJava && window.JsCallJava.call) {
          // Web页面调用应用
          var rst = window.JsCallJava.call("这个是来自本地Web页面的消息");
      } else {
          alert('发送消息给WebviewSlice失败');
      }
  }
</script>
</body>
复制代码

在"slice/MainAbilitySlice.java"中实现应用对Jav前端开发软件aScript发java培训起的调用的响开发者模式打开好还是关闭好应,示例代码如下ÿjava模拟器1a;

private static final String JS_NAME = "JsCallJava";
webview.addJsCallback(JS_NAME, str -> {
    // 处理接收到的JavaScript发送来的消息,本教程通过ToastDialog提示确认收到Web页面发来的消息
    new ToastDialog(this).setText(str).setAlignment(LayoutAlignment.CENTER).show();
    // 返回给JavaScript
    return "Js Call Java Success";
});
复制代码

总结

通过上面的完整代码,javascript我们已经完成了webbiew的基本使用

仓库地址:github.com/ITmxs/hm前端开发_we…

java模拟器二步删除默认代码

打开index.hml文件,里面有默认代码如下&android开发app#xfjavascript百炼成仙f1a;

山茶
复制代码

第三步,开始学习java编译器

首先将图片放到common文件夹下面的imandroid开发ages里面,注意,我的图片文件名是flutter.png,

从上面布局效果图可以看到,界面主要由image组件和text组件组成,我们现在index.html中添加image组件开发者选项在哪和text组件,并添加对应的class,用于设置组件的显示效果,代码如下:

<div class="container">
    <image class="img img-translate" src="/common/images/flutter.png"></image>
    <text class="text">translate</text>
    <image class="img img-rotate" src="/common/images/flutter.png"></image>
    <text class="text">rotate</text>
    <image class="img img-rotateY" src="/common/images/flutter.png"></image>
    <text class="text">rotateY</text>
    <image class="img img-scale" src="/common/images/flutter.png"></image>
    <text class="text">scale</text>
    <image class="img img-opacity" src="/common/images/flutter.png"></image>
    <text class="text">opacity</text>
</div>
复制代码

第四步,为页面设计样式

在这个任务中,我们将一起为任务二中写好的页面添加开发者模式打开好还是关闭好样式,上面所有的组件都定义了class属性,它对应的样式都定义在indexjavascript百炼成仙.css中ÿ移动开发是干什么的0c;有关css更多的知识可以参考candroid开发框架ss语法参考。 这部分定义了整个页面中各个组件的样式。在javascript百炼成仙index开发者模式有什么用.css中先添加如java语言下代码:

.container {
    background-color: #F8FCF5;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.img {
    margin-top: 10px;
    height: 100px;
    width: 100px;
    animation-timing-function: ease;
    animation-duration: 2s;
    animation-delay: 0s;
    animation-fill-mode: forwards;
    animation-iteration-count: infinite;
}
.text {
    font-size: 20px;
}
.img-translate {
    animation-name: translateAnim;
}
.img-rotate {
    animation-name: rotateAnim;
}
.img-rotateY {
    animation-name: rotateYAnim;
}
.img-scale {
    animation-name: scaleAnim;
}
.img-mixes {
    animation-name: mixesAnim;
}
.img-opacity {
    animation-name: opacityAnim;
}
/*从-100px平移到100px*/
@keyframes translateAnim {
    from {
        transform: translate(-100px);
    }
    to {
        transform: translate(100px);
    }
}
/*从0旋转到360*/
@keyframes rotateAnim {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}
/*沿Y轴旋转,从0旋转到360*/
@keyframes rotateYAnim {
    from {
        transform: rotateY(0deg);
    }
    to {
        transform: rotateY(360deg);
    }
}
/*从0倍缩放到1.2倍大小*/
@keyframes scaleAnim {
    from {
        transform: scale(0);
    }
    to {
        transform: scale(1.2);
    }
}
/*透明度从0变化到1*/
@keyframes opacityAnim {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}
复制代码

java培训过一个代码示例,实现image组件的平移、缩放、旋转和透明度变化动效。希望通过本教程,各位开发者可以对JS通用动画样式具android开发框架有更深刻的认识。

鸿蒙-webview的使用和JS交互(附源码)【鸿蒙开发04】

在实现过程过也遇到一些问题,顺便做个记录

使用鸿蒙-webview的使用和JS交互(附源码)【鸿蒙开发04】标签引入的本地图片无法加载开发者选项怎么关闭

使用鸿蒙-webview的使用和JS交互(附源码)【鸿蒙开发04】标签引入本地图片,但图片无法加载的可能情况有三种:

  1. 没有给图片设置宽度和高度,移动开发是干什么的;需要在对应的“page”目录下的 css 样式文件中设android开发工具置图 片的宽高。
  2. 使用鸿蒙-webview的使用和JS交互(附源码)【鸿蒙开发04】标签的图片不会自动缩放,图片宽高超过组件javascript怎么读的宽高会自动 截取。
  3. 图片引入路径错误。图片引入的路径必须是项目编译后的静态文件的路径javascript什么意思。  在导入图片或添开发者模式有什么用加/删除页面后没有重新编译。