Char to Hex in javascript

问题描述 投票:19回答:4

[有人可以指导我如何在javascript中将char转换为十六进制吗?例如:

“入力されたデータは范囲外です。”“ \ u5165 \ u529B \ u3055 \ u308C \ u305F \ u30C7 \ u30FC \ u30BF \ u306F \ u7BC4 \ u56F2 \ u5916 \ u3067 \ u3059 \ u3002”

This site does it

但是我无法弄清楚。

任何建议。

谢谢,萨伯塔姆

javascript char hex
4个回答
28
投票

您可以遍历字符并使用charCodeAt函数获取其UTF-16值,然后使用它们构造一个字符串。

我构建的一些代码比您链接的站点上的代码要好得多,并且应该更容易理解:

function string_as_unicode_escape(input) {
    function pad_four(input) {
        var l = input.length;
        if (l == 0) return '0000';
        if (l == 1) return '000' + input;
        if (l == 2) return '00' + input;
        if (l == 3) return '0' + input;
        return input;
    }
    var output = '';
    for (var i = 0, l = input.length; i < l; i++)
        output += '\\u' + pad_four(input.charCodeAt(i).toString(16));
    return output;
}

让我们分解一下。

  1. [string_as_unicode_escape接受一个参数,input,它是一个字符串。
  2. pad_four是一个内部函数,可以执行一件事;它使用前导'0'字符填充字符串,直到长度至少为四个字符为止。
  3. 首先将output定义为空字符串。
  4. 对于字符串中的每个字符,请将\u附加到output字符串中。用input.charCodeAt(i)取字符的UTF-16值,然后用.toString(16)转换为十六进制字符串,然后用前导零填充,然后将结果附加到output字符串。
  5. 返回output字符串。

正如Tim Down所评论的,我们还可以将0x10000添加到charCodeAt值,然后将.slice(1)添加到调用.toString(16)的字符串上,以实现填充效果。


5
投票
function string_as_unicode_escape(str){
    return str.split("").map(function(s){
        return "\\u"+("0000" + s.charCodeAt(0).toString(16)).slice(-4);
    }).join("");
}

0
投票

var hex = new Array('0','1','2','3','4','5','6','7','8','9','a ','b','c','d','e','f');

    function stringEncode()
    {
        var x=document.getElementById("from_text");


        var preescape="" + x.value;
        var escaped="";

        var i=0;
        for(i=0;i<preescape.length;i++)
        {
            escaped=escaped+encodeChar(preescape.charAt(i));
        }

        //x=document.getElementById("to_text");

                    x.value=escaped;
        //alert("Codigo: "+escapeHtml(escaped));
        //document.getElementById('string_example').innerHTML="<b>String example with text</b><br/><br/>String s=\""+escapeHtml(escaped)+"\";<br/><br/>";
    }


    function escapeHtml(unsafe) {
       return unsafe
                .replace(/&/g, "&amp;")
                .replace(/</g, "&lt;")
                .replace(/>/g, "&gt;")
                .replace(/"/g, "&quot;")
                .replace(/'/g, "&#039;");
            }

            function encodeChar(original)
            {
                    var found=true;
                    var thecharchar=original.charAt(0);
                    var thechar=original.charCodeAt(0);
                    switch(thecharchar) {
                                    case '\n': return "\\n"; break; //newline
                                    case '\r': return "\\r"; break; //Carriage return
                                    case '\'': return "\\'"; break;
                                    case '"': return "\\\""; break;
                                    case '\\': return "\\\\"; break;
                                    case '\t': return "\\t"; break;
                                    case '\b': return "\\b"; break;
                                    case '\f': return "\\f"; break;

                                    default:
                                            found=false;
                                            break;
                            }
                            if(!found)
                            {
                                    if(thechar>127) {
                                            var c=thechar;
                                            var a4=c%16;
                                            c=Math.floor(c/16); 
                                            var a3=c%16;
                                            c=Math.floor(c/16);
                                            var a2=c%16;
                                            c=Math.floor(c/16);
                                            var a1=c%16;
                                    //  alert(a1);
                                            return "\\u"+hex[a1]+hex[a2]+hex[a3]+hex[a4]+"";        
                                    }
                                    else
                                    {
                                            return original;
                                    }
                            }


            }

// ------------------------ lolamarias con


0
投票

您可以为此使用普通的replace()

'! \u0100 力 😃'.replace(
    /[^\x00-\xFF]/g,
    function(ch) {
        return ('\\u0' + ch.charCodeAt(0).toString(16))
            .replace(/0(?=....$)/, '');
    }
)

产生! \u0100 \u529b \ud83d\ude03

非常简洁,可以处理填充问题,而不会造成麻烦的if或慢的slice() s。与in all browsers不同,可以工作map()。请注意,它如何仅替换需要的字符(!未触及),而不会造成麻烦的迭代或缓慢的split()处理。与其他答案一样,它也可以正确处理代理对(😃变成两个字节\ud83d\ude03)。

如果打算多次重用该函数,则将其放在自己的函数中并使两个正则表达式保持静态也会使其更快。

如果确实需要,可以通过将[^\x00-\xFF]更改为.,将\\u0更改为\\u000,将/0(更改为/0+(来处理所有字符。

© www.soinside.com 2019 - 2024. All rights reserved.