转码方式

解码是前端比较常见的一种操作。

特殊符号是否编码

  1. escape: 不编码ASCII字母、数字、标点符号"@ * _ + - . /",对其他所有字符进行编码。
  2. encodeURI: 不编码ASCII字母、数字、标点符号"; / ? : @ & = + $ , #",对其他所有字符进行编码。
  3. encodeURIComponent: 对所有字符进行编码

转码结果

  1. escape: 输出字符的Unicode编码值
  2. encodeURI: 输出符号的utf-8形式,并且在每个字节前加上%
  3. encodeURIComponent: 输出符号的utf-8形式,并且在每个字节前加上%

tips:

  1. 但是我们知道,网页在提交表单的时候,如果有空格,则会被转化为+字符。服务器处理数据的时候,会把+号处理成空格。

注意点

为何解码最好解两次

例如笔者常用的解码方式

javascript 复制代码
function decode(str) {
    var r = '';
    try {
        r = decodeURIComponent(decodeURIComponent(str));   
    }catch(e){
        try {
            r = decodeURIComponent(str);
        } catch(e) {
            try {
                r = unescape(str); //Unicode
            }catch(e) {
                r = str;
            }
        }
    }
    return r;
}
  1. 为什么捕抓异常: 其实decodeURIComponent是会有时候会爆异常的..这个属于bug
  2. 为什么要尝试两次编码、一次编码、和无编码: 因为防止服务端encode两次、一次、或者无编码
  3. 为什么要最后unescape,因为只有这个方法能解析Unicode编码
相关推荐
知识分享小能手43 分钟前
React学习教程,从入门到精通, React 属性(Props)语法知识点与案例详解(14)
前端·javascript·vue.js·学习·react.js·vue·react
luckys.one44 分钟前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
mCell1 小时前
JavaScript 的多线程能力:Worker
前端·javascript·浏览器
weixin_437830943 小时前
使用冰狐智能辅助实现图形列表自动点击:OCR与HID技术详解
开发语言·javascript·ocr
gnip4 小时前
JavaScript事件流
前端·javascript
小菜全4 小时前
基于若依框架Vue+TS导出PDF文件的方法
javascript·vue.js·前端框架·json
wow_DG4 小时前
【Vue2 ✨】Vue2 入门之旅 · 进阶篇(一):响应式原理
前端·javascript·vue.js
weixin_456904274 小时前
UserManagement.vue和Profile.vue详细解释
前端·javascript·vue.js
秋秋小事4 小时前
React Hooks useContext
前端·javascript·react.js
ST.J5 小时前
前端笔记2025
前端·javascript·css·vue.js·笔记