PHP8.1.21版本已发布
vue8.1.21版本已发布
jquery8.1.21版本已发布

HTML实体与网页编码

巴扎黑
巴扎黑 原创
2017-04-05 11:46:02 2020浏览

汉字都转化为了html实体(十进制表示的Unicode编码),这样做的好处就是不管网页的编码是什么,都可以正常的显示汉字,而不会出现乱码,当然也适用于其他字符集。

在php中我们可以用mbstring的mb_convert_encoding函数实现这个正向及反向的转化。
如:

mb_convert_encoding ("你好", "HTML-ENTITIES", "gb2312");    //输出:你好
mb_convert_encoding ("你好", "gb2312", "HTML-ENTITIES");    //输出:你好 
 

如果需要对整个页面转化,则只需要在php文件的头部加上这三行代码:
mb_internal_encoding("gb2312");  // 这里的gb2312是你网站原来的编码
mb_http_output("HTML-ENTITIES");
ob_start('mb_output_handler');
 

Asp版 可以用下面这个函数来实现这个转化:

Function htmlentities(str)
    For i = 1 to Len(str)
        char = mid(str, i, 1)
        If AscW(char) > 0 then
            htmlentities = htmlentities & "" & Ascw(char) & ";"
        Else
            htmlentities = htmlentities & "" & (65536 + ascW(char)) & ";"
        End if
    Next
End Function 

JS 版

 function htmlentities(str)
 {
      var r = "";
      for( i=0; i       {
           temp = str.charCodeAt(i);
           r += ""+temp+";";
      }
     
     //  也可以用一句正则表达式解决
     // r = str.replace(/[\d\D]/g, function($0) { return "" + $0.charCodeAt(0) + ";"; });
     return r;
 }

asp.net (c#) 版
 private string GetHtmlEntities(string str)
  {
      string r = string.Empty;
       for (int i = 0; i        {
            r += ""+Char.ConvertToUtf32(str,i)+";";
       }
       return r;
 }

相关文档:网页中常用HTML字符实体

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。