js插入的中文乱码

昨晚把静态页面中的javascript单独提取出来作为单独的js文件部署后没有再检查一遍(😭),第二天就看到js填充的中文文本都乱码了,记录下解决过程。

  1. 先检查页面,查看浏览器调试面板中的network中的js文件请求,看到请求的js文件中的中文是乱码的;
  2. 直接运行django项目查看,看到页面没有乱码,js文件也没有乱码,但是network中js文件的preview里面的中文是乱码的,确认下js文件是utf-8编码,script标签添加’charset’解决;
    <script charset="utf-8" src="XXX" type="text/javascript"></script>
    
  3. 此时页面还是乱码,应该是nginx的原因,查看nginx的配置文件;
    server配置下面的charset设置的是gbk,utf8,修改为utf8后重新部署,乱码问题解决。

中间搜索资料看到网上有人说需要把sendfile设置成off,查了下感觉莫名其妙,文件传输方式不同不应该会导致乱码,试了下果然不是这个的原因。。。nginx中配置sendfile及详细说明
快捷键:Ctrl+F5->硬性重新加载;F5->正常重新加载;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当使用JavaScript通过`window.location.href`来下载文件,并且文件名包含文时,可能会遇到乱码的问题。这主要是因为浏览器默认使用的是系统编码或者是UTF-8等通用编码来进行URL拼接,而某些本地系统的默认字符集(如GBK、GB2312等支持文的编码)与网页显示使用的编码可能存在差异。 ### 解决方案: 为了防止文名称乱码,可以采用以下几种方法之一: #### 方案一:使用 Blob 和 URL.createObjectURL API 这种方式将文件数据转换成Blob对象,并利用`URL.createObjectURL()`创建一个临时URL,进而生成可直接点击的链接来下载文件。 ```javascript function downloadFile(filename, content) { const url = URL.createObjectURL(new Blob([content], { type: 'application/octet-stream' })); const a = document.createElement('a'); a.style.display = 'none'; a.href = url; a.download = filename; document.body.appendChild(a); a.click(); setTimeout(() => { URL.revokeObjectURL(url); a.remove(); }, 0); } // 使用示例 downloadFile('测试文件.xlsx', '您的文件内容...'); ``` #### 方案二:指定合适的Content-Disposition 修改HTTP头信息,指定文件下载时不显示文件名提示,而是由用户自行选择保存位置和命名。这是通过在响应头添加特定的值来实现的。 ```javascript fetch('路径到您的文件') .then(response => response.blob()) .then(blob => { let link = document.createElement("a"); link.href = window.URL.createObjectURL(blob); link.setAttribute("download", "测试文件.xlsx"); // 指定文件名及扩展名 link.style.display = "none"; document.body.appendChild(link); link.click(); // 触发下载事件 window.URL.revokeObjectURL(link.href); // 释放内存引用 document.body.removeChild(link); }); ``` ### 相关问题: 1. **如何避免在其他浏览器环境下使用此方法?** 针对不同的浏览器环境调整编码设置或使用兼容性更高的方法。 2. **为什么某些编码会导致乱码现象?** 主要是由于文件名的编码与浏览器解析编码之间的不一致导致,涉及到字符集的相互翻译过程。 3. **除了上述方法外还有哪些解决文文件名乱码的策略?** 可以尝试使用Base64编码文件数据,然后通过HTML `<a>` 标签的 `href` 属性创建下载链接,再结合JavaScript动态插入下载触发脚本来实现文件下载。这种方法也能够有效处理文件名文字符。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值