String.split( “¤”);不工作

时间:2015-11-05 18:58:36

标签: javascript string split currency sign

所以,我从学校得到了这个让我疯狂的任务。我将从.dat文件中获取数据,其中包含:

812¤SuperIT¤2015-12-0618:00¤25

614¤MediaHuset¤2016-01-1416:15¤67

如果我用例如“;”替换“¤”,我的脚本可以工作,但它不适用于“¤”,“¤”,“¤

window.onload = start;

var xhttp;

function start() {
    document.getElementById('sub').onclick = load;
}

function load() {
    xhttp = new XMLHttpRequest();
    xhttp.onreadystatechange = statusChange;
    xhttp.open('GET', '../presentasjoner.dat', true);   //GET or POST
    xhttp.send();

}
function statusChange() {
    if (xhttp.readyState === 4 && xhttp.status === 200) {
        var content = xhttp.responseText;
        var lines = content.split("\n");

        document.getElementById('table').innerHTML = "";
        for (var i = 0; i < lines.length; i++) {
            var parts = lines[i].split('&curren;');

            document.getElementById('table').innerHTML +=
            "<h4>" + parts[0] + "</h4>" +
            parts[1] + "<br/>" +
            "Antall plasser: " + parts[2] + "<br/>";
        }
    }
}

HTML看起来像这样:

<!DOCTYPE html>
<html> 
    <head>
        <meta charset="UTF-8">
        <title>Oppgave 1 - Oblig 5</title>
        <link rel="stylesheet" href="../css/common.css">
        <link rel="stylesheet" href="../css/common.css">
        <script type="text/javascript" src="../js/oppg1.js"></script>
    </head>

    <body>
        <div class="commonDiv">
            <a href="http://ask.hiof.no/~joakimsg/GRIT/WEB/html/fanpage.html"><h1>Oblig 4, Joakim Granaas</h1></a><br/>
            <h3>Oppgave 1</h3><br/>
            <input id ="sub" type ="submit" /><br/>
            <div   id="table"></div>
        </div>
    </body>
</html>

2 个答案:

答案 0 :(得分:0)

¤可能只是一个不可打印的角色。使用od -c找出它实际上是什么,并将其拆分。

$ echo 'abc' | od -c
0000000   a   b   c  \n
0000004

答案 1 :(得分:0)

按“¤”def分裂。工作,请看这里:https://jsfiddle.net/s7t0c5jg/ ---所以问题是你的代码中的其他地方或你的浏览器很难处理“¤”或你将文件保存为UTF8或其他东西,“¤”可能是比UTF8更高的字符?

阅读上面的评论后,我认为 Axel 是正确的说“通常¤只是表示不可打印的字符,并不表示此字符实际上在您的内容中使用十六进制编辑器打开数据文件并查看非常分隔符ascii值“

JSFiddle来源:

<!DOCTYPE html>
<html>
<body>
<button onclick="myFunction()">split by "¤"</button>
<p id="result"></p>
<script>
function myFunction() {
    var str = "Item1 ¤ Item2 ¤ Item3 ¤ Item4";
    var res = str.split("¤");
    document.getElementById("result").innerHTML = res;
}
</script>
</body>
</html>