JavaScript OnClick 传值的解决方案 搭配模板引擎

//假设是一个任意值的Object
var data = {"name":"Nameless"}; 

// Data 转码
//使用JSON.stringify()将Object转为JSON
//然后使用encodeURIComponent()对特殊文字(中文字符等非ascii)进行转码
//在使用btoa()转换成base64
let dataEncode = btoa(encodeURIComponent(JSON.stringify(data))); 
//传值
var buttonItem = '<a οnclick="detailMachine(\''+dataEncode+'\');">';
// Data 解码
const dataDecodeFc = (data)=>{
let dataDecode = JSON.parse(decodeURIComponent(atob(data)));
}

直接转成JSON可能会遇到 ",'(). 等标点符合混乱导致各种SyntaxError,上述代码将原始数据data先将非ascii字符转为万国码,然后将万国码联通数据一同转为base64,杜绝因为JSON与Javascript各种奇妙错误,由于这是在客户浏览器端进行的对服务器压力没那么大
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值