我的编程空间,编程开发者的网络收藏夹
学习永远不晚

好程序员web前端教程分享js文件引用编码方式

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

好程序员web前端教程分享js文件引用编码方式

好程序员web前端教程分享js文件引用编码方式,js外部文件编码由这些因素决定:1.如果Apache有DefaultCharset,则js文件解析用服务器指定的编码;2.如果PHP header声明charset为编码utf-8,则文件编码用utf-8来解析。3.如果以上两个都为空,页面编码由meta标签决定。4.如果以上声明都没有,则会使用utf-8来解析。5.如果页面编码为gbk,而js文件编码为utf-8,则可以在js属性中定义charset='utf-8'。

 

昨天帮同事解决的一个问题,GBK的页面(不要问我为什么GBK,因为GBK,所以GBK),引用了Google map的API, 但是由于GoogleMap API返回的js脚本是utf-8的,所以导致在IE下, 浏览器无法正确解析.

 

也就是, 由于服务器中生成的HTML是基于gbk编码的, 并且由于Apache的DefaultCharset(后叙), 所以导致IE会以gbk编码去解析从外部引入的GoogleMap js,那肯定是不能正确解释的.

 

浏览器判断一个页面的编码有俩个途径, 一种是通过HTTP响应头,

 

HTTP/1.x 200 OK

Date: Sat, 18 Oct 2008 21:53:51 GMT

Server: Apache/2.0.52 (Red Hat)

X-Powered-By: PHP/5.3.0alpha2

Connection: close

Transfer-Encoding: chunked

Content-Type: text/html; charset=GB2312

注意最后一行, 这个是由HTTP头部指明的页面编码格式.

 

另外一种就是我们常见的, 也会另很多初学者困惑的meta:

 

问题就在于,没有一个统一的标准,来指明这俩中方式的优先级, 不同的浏览器有着不同的优先级策略.这也就是为什么,我们在FF下正常浏览的页面,在IE下会乱码的原因.

 

我之前的文章Apache的Charset设置中已经介绍过了在Apache下设置DefaultCharset以后产生的影响,

 

这个问题已经遇到过俩次了,就是页面中明确指明了编码是UTF8,但是显示是乱码。

 

虽然知道解决方法,也知道是Apache的原因,但是一直没有去找其所以然,今天趁机,就研究了一下。

 

页面没有指定charset , Apache配置defaultcharst gbk , 页面文件编码是utf-8

 

结果: 乱码,使用wireshark抓包,发现服务器返回的header中指明了:

 

Content-Type:text/html;charset=GBK

结论:当页面没有指明charset的时候,Apache的defaultcharset起作用

 

页面指定charset为utf-8, Apache配置defaultcharset gbk. 页面文件是utf-8

 

<head>

        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

</head>

<body>

        <div id="page-header">

         测试Apache DefaultCharset

        </div>

</body>

</html>

结果还是出现乱码。

 

结论:当Apache配置了DefaultCharset, 将忽略页面的charset申明。

 

3 PHP header申明charset为utf8, Apache配置defaultcharst gbk,页面文件编码是utf8

 

header("Content-Type:text/html; charset=utf-8");

结果 : 页面显示正常。

 

4 Apache设置DefaultCharset off

 

结果,页面显示正常。

 

翻阅了下Apache2的手册:

 

AddDefaultCharset指令

说明当应答内容是text/plain或text/html时,在HTTP应答头中加入的默认字符集

语法AddDefaultCharsetOn|Off|charset

默认值AddDefaultCharsetOff

作用域serverconfig,virtualhost,directory,.htaccess

覆盖项FileInfo

状态核心(C)

模块core

 

当且仅当应答内容是text/plain或text/html时,此指令将会在HTTP应答头中加入的

默认字符集。理论上这将覆盖在文档体中通过<meta>标 签指定的字符集,但是实际

的行为通常取决于用户浏览器的设置。AddDefaultCharsetOff将会禁用此功能。

 

AddDefaultCharsetOn将启用Apache内部的默认字符集iso-8859-1。您

也可以指定使用在IANA注册过的字符集名字 中的另外一个charset。

比如说:

AddDefaultCharsetutf-8

也就是说,当Apache不指定defaultcharset的时候,页面编码由页面自己的meta标签指定。

 

当Apache指定的时候,将忽略页面中的meta标签指定的编码. 但是容许脚本直接header编码方式给客户端

 

最后,还有一个问题没有得出结果:

 

当Apache和页面都没有指定的时候, 又如何?

 

我在自己的机器上,如果都不指定, 默认还是utf8

 

在服务器端生成response内容以后, 如果脚本没有显示的调用header发送编码申明,那么Apache就会根据DefaultCharset生成响应HTTP头部的Content-type中的charset字段;

 

反之如果脚本显示申明了,那么就会按照脚本header申明中的charset设置.

 

这样到了浏览器端以后, 浏览器就可以根据HTTP头的charset申明来按照特定的编码格式解析获取到的HTML代码,但现在的问题是, 页面是GBK的,但是引用的外部js文件是utf8编码的,这样的情况, 我们可以使用一个script的属性来解决:

 

  <script language='javascript' class="lazy" data-src='....'  charset='utf-8'></script>

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

好程序员web前端教程分享js文件引用编码方式

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

好程序员web前端教程分享js文件引用编码方式

好程序员web前端教程分享js文件引用编码方式,js外部文件编码由这些因素决定:1.如果Apache有DefaultCharset,则js文件解析用服务器指定的编码;2.如果PHP header声明charset为编码utf-8,则文件编码
2023-06-03

好程序员web前端分享CSS文件引用的最优方法

好程序员web前端分享CSS文件引用的最优方法,在html总引入css文件的方法:   1链接式:   2导入式:   区别:   使用链接式时,会在加载页面主体部分之前加载css文件,这样现实出来的页面一开始就是带有样式效果的,而使用导入
2023-06-03

好程序员web前端分享JS引擎的执行机制

  好程序员web前端分享JS引擎的执行机制,请先着重牢记两点!JS是单线程语言。   JS的EventLoop是JS的执行机制。深入了解JS的执行,就等于深入了解JS里的eventloop。   1、灵魂三问:JS为什么是单线程的?为什么
2023-06-03

好程序员web前端教程分享CSS预编译器的再次理解

  好程序员web前端教程分享CSS预编译器的再次理解:我所理解的css预编译器   基于css的,能让css也有一种编程语言范。解决了css的诸多问题,如css模块化、无法嵌套书写、没有变量。   css模块化   这个对于项目公司的项目
2023-06-03

好程序员web前端分享CSS3颜色值HSLA表示方式

说明:本文档兼容性测试基础环境为:windows系统;IE6-IE10, Firefox6.0, Chrome13.0, Safari5.1, Opera11.51说明:HSLA(H,S,L,A)取值:H:Hue(色调)。0(或360)表示
2023-06-03

好程序员web前端教程分享JavaScript学习笔记之Event事件二

  好程序员web前端教程分享JavaScript学习笔记之Event事件二,今天来聊一聊事件的执行机制。  什么是事件的执行机制呢?  思考一个问题?  当一个大盒子嵌套一个小盒子的时候,并且两个盒子都有点击事件你点击里面的小盒子,外面的
2023-06-03

好程序员web前端分享使用JavaScript正则表达式如何去掉双引号

  好程序员web前端分享使用JavaScript正则表达式如何去掉双引号,最近接了一个项目,项目需求需要用js正则表达式过滤掉页面文本域中值得双引号,其实解决办法很简单,下面把我写的代码分享给大家,有同样需求的朋友可以参考下。   具体的
2023-06-03

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录