问题提出:在进行页面书写的时候,有时候需要进行动态页面拼接,在动态拼接的时候,涉及到函数的调用,函数的传值可能是HTML标签,或者含有json的标签,这样在传值时就有可能出现问题,由于”“的存在,html会对其进行解析,把不该显示的元素进行了显示,这里提出一种解决思路。

如上图所示,我的detail变量和poet变量都是从服务器上获取的数据,其中poet为字符串,detail为json格式数据,这里对它进行了组装,组装成一个名为poetinfo的JSON数组,detail中含有了大量的html标签,其形式如下图所示,linkhtml是我需要动态拼接的组件,这里调用了一个函数为NewView(),这里需要将poetinfo的JSON传入NewView函数中使用。

开始的时候想的是直接将JSON作为NewView的参数写入写法为:

  linkHtml = "<div style='text-align:center'>" + "<a id=\"" + poet +
                 "\" href='javascript: NewView(\"" +
                 poetinfo +"\")' class='expand'+v.poetname +"</a>" + "<span style='color:blue;font-size:7px'>" + v.year + "</span>" + "</div>";

如果不用字符串形式,传过去的JSON将变为形为”[object object]“的字符串,如果提前使用了JSON.Stringify()函数,再进行传出,则会出现这里的值出现在div容器中,这是因为再detail中有引号,打乱了原本的标签结构。

这里有两种解决思路,第一种是将从服务器获取的数据全部转存到一个JSON,然后在每次遍历时设置一个索引,通过数字索引访问JSON对象,这种方法不够直观,并且索引的计算和数据的储存过大。

这里提出一种想法,方便在写动态拼接大量标签的网页时传值的方法,同时适用的场景还可以是,在我们使用JS的时候,有时候需要从服务器获取数据,为了减小服务器压力,不每次都从服务器调用数据,我们可以采用利用标签属性存值的方式进行储存和调用。

问题解决:

  • 将JSON储存在某一个标签的某一个属性中,在储存的时候为了不破坏结构,可以先对其进行编码,编码的方法,JS自带的有window.btoa()方法和网页中使用的encodeURIComponent()方法,第一种方法创建一个 base-64 编码的字符串,使用 “A-Z”, “a-z”, “0-9”, “+”, “/” 和 “=” 字符来编码字符串,第二个就是网页中使用的URL编码,这样就可以进行包装不破坏拼接标签的结构

  • 在编码前需要将其转化为字符串类型也就是使用JSON.stringify(),总的代码为encodeURIComponent(JSON.stringify(poetinfo)),然后将其存放在一个标签中,并用一个值来给这个标签设置id属性。

  • 在传值的时候将标签的id传出去,方便DOM操作,在其他函数调用时,可以通过id进行DOM操作,获取DOM属性,获取的方法可以是原生的Document.getelementById("id").getAttribute("名称"),也可以采用Jequry的$("#id").attr("属性名称")

  • 然后获取到这个属性后,先进行解码,然后再使用JSON.prase()就可以获取原来的JSON数据了,使用btoa加密的代码,解码方式为window.atob(),使用URL加密的解密方法为decodeURIComponent(),综合代码为JSON.parse(decodeURIComponent($('#' + poet).attr("poetinfo")));

JS传值与应用的更多相关文章

  1. JS传值中文乱码解决方案

    JS传值中文乱码解决方案 一.相关知识 1,Java相关类: (1)java.net.URLDecoder类 HTML格式解码的实用工具类,有一个静态方法:public static  String ...

  2. JS 传值 传址

    在JS中,有两种不同的方式可以操作数据的值,这两种技术分别叫做 传值 和 传址. 传值:在赋值过程中,首先对值进行了一份拷贝,而后将这份拷贝存储到一个变量.对象属性或数组元素中.拷贝的值和原始的值是完 ...

  3. JS传值和传引用

    之前看<javascript高级程序设计>时就遇到过一个问题,就是函数传参的问题,书上说是按值传递,而非按引用传递.很多人都会认为js里面有两种传值方式,一种是复制,另一种是数组.对象等按 ...

  4. 通过js获取UserAgent写入数据库 js传值至php

    借助cookie,cookie是js和php互相传值的纽带.

  5. 再谈js传值和传址

    js的传值和传址还是真绕,前回文说道 1.值类型是传值的 2.对象和数组是传址的 这两点通过例子的到了证实 然而还有一种情况没有讨论 即 函数的参数的传值和传址 通过实验,在函数中用一个新对象去覆盖传 ...

  6. Flask向模板中JS传值简便方式

    后台传值: return render_template('statistics/numberofuserlogin/login_number.html', result_json = json.du ...

  7. js传值

    //传值$('.choose li').click(function(){    //alert('z');     $("#address").empty().prepend($ ...

  8. web后台获取不到session中的值(loading sessions from persistent storage),后改用JS传值

    线上的程序似乎从session中取不到domain数据,重启了一下tomcat查看log日志发现,居然有报错.错误信息如下 22-Sep-2016 00:52:16.562 SEVERE [local ...

  9. 也谈js传值和传址

    通常的认识就是基本的数值元素是传值,对象等复杂结构传址,无需争论,一试便知. 首先是数值 var a = 1 var b = a a = 2 console.log(a) console.log(b) ...

  10. js传值到后台乱码问题

    1.前台js的路径 var addurl1="ldcOrderController.do?goods&orderGoodsExtra="+encodeURI(encodeU ...

随机推荐

  1. 使用FastDFS打造一款高可用的分布式文件系统

    FastDFS 介绍 参考: http://www.oschina.net/p/fastdfs FastDFS 是一个开源的分布式文件系统,它对文件进行管理,功能包括:文件存储.文件同步.文件访问(文 ...

  2. 为什么阿里Java开发手册不推荐使用Timestamp

    开发手册 不推荐用java.sql.Date.java.sql.Time网上说的文章有很多. 参考文章:一文告诉你Java日期时间API到底有多烂 但为什么不推荐使用java.sql.Timestam ...

  3. HDU4734 F(x) (数位DP)

    (如此简短的题目给人一种莫名的压迫感......) 题目中定义一个数的权值求解函数:F(x) = An * 2n-1 + An-1 * 2n-2 + ... + A2 * 2 + A1 * 1. 观察 ...

  4. SpringBoot(七) - Redis 缓存

    1.五大基本数据类型和操作 1.1 字符串-string 命令 说明 set key value 如果key还没有,那就可以添加,如果key已经存在了,那会覆盖原有key的值 get key 如果ke ...

  5. 2022年实时最新省市区县乡镇街道geojson行政边界数据获取方法

    geojson 数据下载地址:https://hxkj.vip/demo/echartsMap/ 可下载的数据包含省级geojson行政边界数据.市级geojson行政边界数据.区/县级geojson ...

  6. mujoco d4rl 安装问题

    最近mujoco免费了,属实爽歪歪,安装d4rl没有以前那么麻烦了(不知为何半年前我安装d4rl时走了那么多弯路) mujoco安装 在 https://mujoco.org/download 上面下 ...

  7. 【做题笔记】CSP-S 往年试题

    题单 本文章正在持续更新-- [2021] 廊桥分配 题目 题面描述 所有飞机分为两类--国内区和国际区,两区廊桥数量互不干扰.每架飞机遵循"先到先得"的原则,优先选择编号最小的廊 ...

  8. Django之同时新增数据到两个数据库表与同时返回两个表的数据(插拔式)

    models:比如有以下三个模型 from django.db import models """ 基类,其他类继承即可获得对应的字段 """ ...

  9. Unity——第一人称控制器的实现

    Unity--第一人称控制器的实现 一.功能描述 在一个场景中实现人物的前后左右移动和跳跃功能:其中前后左右移动通过W.A.S.D方向键实现,跳跃功能通过空格键实现,并且考虑到重力作用,来调节跳跃功能 ...

  10. 【k8s】k8s pv、pvc无法删除问题。

    一般删除步骤为:先删除pod再删除pvc最后删除pv 遇到的问题 但是遇到pv使用处于"Terminating"状态,而且删不掉.如下图: 解决办法 直接删除k8s中的记录: ku ...