html转成字符串_js转string类型

html转成字符串_js转string类型看到一个牛人的博客http://riny.net/lab/#tools_html2js看了下他的代码挺棒的所依赖的两个库在这里https://github.com/Bubblings/lab/t

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

看到一个牛人的博客  
http://riny.net/lab/#tools_html2js

 

看了下他的代码  挺棒的  

所依赖的两个库在这里 https://github.com/Bubblings/lab/tree/master/tools/js

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>

<style type="text/css">
body {
    background-color: #fafafa;
}
.html2js {
    width: 800px;
    margin: 5px auto 0;
}

#html, #javascript {
    width: 790px;
    height: 190px;
    padding: 5px;
    border: 1px solid #ccc;
    box-shadow: 2px 2px 5px rgba(0,0,0,.1);
}
h2 {
    text-align: center;
}
p {
    margin: 10px 0;
    line-height: 20px;
}
button {
    margin-right: 5px;
}
#is-array {
    margin: 0 3px 0 5px;
    width: 13px;
    height: 13px;
}
label {
    display: inline-block;
}
select {
    width: auto;
    font-size: 14px;
}
</style>

<div class="html2js">
    <h2>html代码转javascript</h2>
    <p>需要转换的html代码</p>
    <textarea name="" id="html"></textarea>
    <p>
        <button class="btn btn-primary" id="single-btn">转单引号格式</button>
        <button class="btn btn-primary" id="double-btn">转双引号格式</button>
        <input type="checkbox" name="" id="is-array" checked><label for="is-array">数组拼接</label>
        <select name="indent" id="indent">
            <option value="1">制表符缩进</option>
            <option value="2">2个空格缩进</option>
            <option value="4" selected>4个空格缩进</option>
        </select>
    </p>
    <p>生成的javascript代码</p>
    <textarea name="" id="javascript"></textarea>
</div>

<script src="htmlFormat.js"></script>
<script src="jsFormat.js"></script>
<script>
    function html2js(html, quotes, isArray) {
        var arr = html.split('\n');
        var reg = new RegExp(quotes, 'g');
        for (var i = arr.length - 1; i >= 0; i--) {
            var cur = arr[i].replace(reg, '\\' + quotes); //假如我要转为的js字符串是单引号包裹的  那么html属性中的单引号需要转义
            var startSpace = cur.match(/^\s*/g); //取到一行开头的空格(缩进)
            cur = cur.replace(/^\s*|\s*$/, ''); //去掉开头和结尾的空格
            if (cur === '') {
                arr.splice(i, 1); //如果是空行  则丢弃  注意splice是在原有数组上操作的
                continue;
            }
            cur = startSpace + quotes + cur + quotes;
            arr[i] = cur;
        }
        if (isArray) {
            return '[\n' + arr.join(',\n') + '\n].join('+ quotes + quotes +');'
        } else {
            return arr.join(' +\n') + ';';
        }
    }

    var htmlEle = document.getElementById('html');
    var jsEle = document.getElementById('javascript');
    var singleBtn = document.getElementById('single-btn');
    var doubleBtn = document.getElementById('double-btn');
    var checkbox = document.getElementById('is-array');

    singleBtn.onclick = function () {
        transform('\'');
    };

    doubleBtn.onclick = function () {
        transform('\"');
    }
    /*
    转换原理
    先将html片段格式化
    再将每一行的开头加上引号  (html中本身的引号要转义)
     */
    function transform(quotes) {
        var input = htmlEle.value;//.replace(/^\s*/, '');//去除开头的空格 //注意这里的input只有一行
        var indentSize = document.getElementById('indent').value;
        var indentChar = ' ';
        if (indentSize == 1) {
            indentChar = '\t';
        }
        input = style_html(input, indentSize, indentChar, 800); //格式化后的input //仍只有一行
        jsEle.value = html2js(input, quotes, checkbox.checked);
    }
</script>
</body>
</html>

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/166515.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 当小样本遇上机器学习 fewshot learning

    当小样本遇上机器学习 fewshot learning引言深度学习(deeplearning)已经广泛应用于各个领域,解决各类问题,例如在图像分类问题下,如图1,区分这10类目标的准确率目前可以轻松做到94%。然而,deeplearning是一种datahungry的技术,需要大量的标注样本才能发挥作用。图1现实世界中,有很多问题是没有这么多的标注数据的,获取标注数据的成本也非常大,例如在医疗领域、安全领域等。因此,我们现在讨论的是…

    2022年4月28日
    64
  • outputstream转byte数组_byte数组写入文件

    outputstream转byte数组_byte数组写入文件将inputstream转化为数组byte[]

    2022年9月21日
    2
  • 文件句柄数_系统文件句柄

    文件句柄数_系统文件句柄内核参数fs.file-max指定了系统范围内所有进程可打开的文件句柄的数量限制。合理值计算方法:取决于内存,每1M内存可增加100个。默认情况下,不要将超过10%的内存用于文件。将文件句柄数设置太大的危害是,当大量的文件句柄都为sockets时,会占用大量的内存,这些内存都是不可交换的。要记得的是网络套接字连接符也是文件。对于百万级连接数的进程来说,要设置单个进程可打开的文件句柄数为百万个。比如256G内存,应该配置的值为:256*0.1*1024*100=2621440设置方式:vi/et

    2022年10月17日
    1
  • 查看sql_mode_mysql命令行执行sql脚本

    查看sql_mode_mysql命令行执行sql脚本1,执行SQL查看select@@session.sql_mode;全局级别:查看select@@global.sql_mode;2,修改set@@session.sql_mode=’xx_mode’setsessionsql_mode=’xx_mode’全局级别:修改setglobalsql_mode=’xx_mode’;set@@global.sql_mode=’xx_mode’;session均可省略,默认session,仅对当前会话有效全局修改的话,

    2022年9月1日
    6
  • 【数据仓库】【第十章】ODS层「建议收藏」

    【数据仓库】【第十章】ODS层「建议收藏」1.创建数据库现在数仓环境已经搭建好了;数据也都已经采集到hdfs上了;1)启动hive[atguigu@hadoop102hive]$bin/hive2)显示数据库hive(default)>showdatabases;3)创建数据库hive(default)>createdatabasegmall;4)使用数据库hive(default)>usegmall;ODS层1.用户行为数据(1)建表分析一行数据是什么:一条日志有哪些字段:

    2022年10月5日
    2
  • Render,RenderChildren,RenderControl

    Render,RenderChildren,RenderControlprotectedinternalvirtualvoidRender(HtmlTextWriterwriter){this.RenderChildren(writer);}protectedinternalvirtualvoidRenderChildren(HtmlTextWriterwriter){ICollectionchildren=(th…

    2022年7月20日
    12

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号