开发者社区> 凌浩雨> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

Andorid Freemarker与template.js使用

简介: 1. Freemarker官方网站 注:官网下载的freemarker是无法直接应用到Android中的,如果要使用需要修改源码测试代码下载 1). 在assets文件夹下创建main.
+关注继续查看

1. Freemarker官方网站

注:官网下载的freemarker是无法直接应用到Android中的,如果要使用需要修改源码
测试代码下载

1). 在assets文件夹下创建main.tpl文件, 其中${user}为动态替换的内容

<html>
<head>
    <title>Welcome!</title>
</head>
<body>
<h1>Welcome ${user}!</h1>
<p>Our latest product:</p>
</body>
</html>

2). 导入freemarker.jar与openbeans.jar

    compile files('libs/freemarker.jar')
    compile files('libs/openbeans.jar')

3). 将main.tpl文件拷贝至项目的/data/data/package/file/目录下,并更名为main.ftl

    /**
     * 准备模板
     * @throws IOException
     */
    private void prepareTemplate() throws IOException {
        // 获取app目录 data/data/package/file/
        String destPath = getFilesDir().getAbsolutePath();
        File dir = new File(destPath);

        // 判断文件夹是否存在
        if (!dir.exists()){
            dir.mkdir();
        }

        // 需要生成的.ftl模板文件名及路径
        String tempFile = destPath + "/" + "main.ftl";
        if (!(new File(tempFile).exists())){
            // 获取assets中.tpl模板文件
            InputStream is = getResources().getAssets().open("main.tpl");
            // 生成.ftl模板文件
            FileOutputStream fos = new FileOutputStream(tempFile);
            byte[] buffer = new byte[7168];
            int len;
            while ((len = is.read(buffer)) > 0){
                fos.write(buffer, 0, len);
            }
            fos.flush();
            fos.close();
            is.close();
        }
    }

4). 根据main.ftl文件生成对应的main.html网页

    /**
     * 生成网页
     * @throws IOException
     * @throws TemplateException
     */
    private void genHTML() throws IOException, TemplateException {
        String destPath = getFilesDir().getAbsolutePath();
        FileWriter out = null;
        // 数据源
        Map<String, String> root = new HashMap<>();
        // 传入字符串
        root.put("user", "mazaiting");
        Configuration cfg = new Configuration(new Version(2, 3, 25));
        // 设置编码字符
        cfg.setDefaultEncoding("UTF-8");
        // 设置报错提示
        cfg.setTemplateExceptionHandler(TemplateExceptionHandler.RETHROW_HANDLER);
        // 设置报错提示
        cfg.setLogTemplateExceptions(true);
        out = new FileWriter(new File(destPath + "main.html"));
        // 设置.ftl模板文件路径
        cfg.setDirectoryForTemplateLoading(new File(destPath));
        // 设置template加载的.ftl模板文件名称
        Template temp = cfg.getTemplate("main.ftl");
        // 将数据源和模板生成.html文件
        temp.process(root, out);
        out.flush();
        out.close();
    }

5). 在WebView中加载网页

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

        try {
            prepareTemplate();
            genHTML();

            mWebView.post(new Runnable() {
                @Override
                public void run() {
                    String templateDir = getFilesDir().getAbsolutePath();
                    String url = "file://" + templateDir + "main.html";
                    mWebView.loadUrl(url);
                }
            });
        } catch (Exception e) {
            e.printStackTrace();
        }

2. template.js项目地址

1). 在assets文件夹下引入template.js文件
2). 编写main.html文件

<html lang="en">

<head>
    <title>Welcome!</title>
</head>
<body>
<script id="script1" type="text/html">
    <h1>Welcome <%=user%>!</h1>
</script>

<div id="contentTop"></div>
<p>Our latest product</p>
<script src="template.js"></script>
<script>
        <!--从java代码中获取到数据-->
        var data = JSON.parse(window.java.getString());
        var tpl = template(document.getElementById('script1').innerHTML);
        var html = tpl(data);
        document.getElementById('contentTop').innerHTML = html;
</script>
</body>
</html>

3). 对WebView进行设置

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

        // 设置webView允许JavaScript
        mWebView.getSettings().setJavaScriptEnabled(true);
        // 创建JSON对象
        final JSONObject jsonObject = new JSONObject();
        try {
            jsonObject.put("user", "mazaiting");
        } catch (JSONException e) {
            e.printStackTrace();
        }
        // 设置JavaScript执行的方法
        mWebView.addJavascriptInterface(new Object(){
            @JavascriptInterface
            public String getString() {
                return jsonObject.toString();
            }
        }, "java");
        try {
            // 设置网页
            mWebView.post(new Runnable() {
                @Override
                public void run() {
                    String url = "file:///android_asset/main.html";
                    mWebView.loadUrl(url);
                }
            });
        } catch (Exception e) {
            e.printStackTrace();
        }

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
若依V3 | RuoYi-Vue3-JS Doc
个人比较喜欢vue3的开发方式,目前也是全职前端,使用vue来作为技术站开发。在这里使用若依,并没有打算抄袭人家的成果,只是偶然在gitee的评价中看到,官方目前没有打算使用Vue3来更新前端。
0 0
vue-ant design示例大全——按钮本地css/js资源
vue-ant design示例大全——按钮本地css/js资源
0 0
Vue.Js中过滤器的简单使用
Vue.js中允许我们自定义过滤器对一些常见的文本进行格式化操作。由管道符指示, 语法格式如下:
0 0
springboot html vue.js 前后分离代码示例
springboot html vue.js 前后分离代码示例
0 0
使用纯粹的JS构建 Web Component
Web Component 出现有一阵子了。 Google 费了很大力气去推动它更广泛的应用,但是除 Opera 和 Chrome 以外的多数主流浏览器对它的支持仍然不够理想。
0 0
js template实现方法
培训类型:入园-家长会 待回访 ...
544 0
Knockout.Js官网学习(Mapping插件)
前言   Knockout设计成允许你使用任何JavaScript对象作为view model。必须view model的一些属性是observable的,你可以使用KO绑定他们到你的UI元素上,当这些observable值改变的时候,这些UI元素就会自动更新。
728 0
js模板引擎,哪个好
js模板引擎模板引擎是为了使用户界面与业务数据(内容)分离而产生的,它可以生成特定格式的文档,用于网站的模板引擎就会生成一个标准的HTML文档。js模板引擎包括如下:template官方参考:http://aui.
623 0
+关注
凌浩雨
毕业于贵州大学大数据与信息工程学院,目前是一名移动端工程师,就职于北京乾元大通信息技术有限责任公司。
文章
问答
文章排行榜
最热
最新
相关课程
更多
相关电子书
更多
利用编译将 Vue 组件转成 React 组件
立即下载
基于webpack和npm的前端组件化实践
立即下载
低代码开发师(初级)实战教程
立即下载