【js】数据处理报错

新手上路,请多包涵

制作一个简易解析器,使用正则表达式。在textarea中导入的数据没有替换字符成功
只希望导入的数据能替换字符;
matchArry[0]报错

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <textarea id="show" spellcheck="true"># 猪</textarea>
    <input type="file" id="file1">
    <input type="button" id="btn" onclick="rec()" value="转换">
    <script>
        var filein = document.getElementById('file1'),
            showbox = document.getElementById('show');
        filein.addEventListener('change', function () {
            var file = filein.files[0];
            var reader = new FileReader();
            reader.onload = function (e) {
                var data = e.target.result;
                showbox.innerHTML = data;
            };
            reader.readAsText(file, 'utf-8');
        });

        function rec() {
            var textarea = document.getElementById('show');

            textarea.innerHTML = main(textarea.value); //检验可以写入字符串

        }

        function main(evt) {
            var char = evt.split("\n");
            var matchArry;
            var html = '';
            var len = char.length;

            for (var i = 0; i < len; i++) {
                matchArry = char[i].match(/^#\s/); //切割成[""]

                if (matchArry[0]) {
                    switch (matchArry[0]) { //导入了空的字符串和不匹配字符串则会报错
                        case '# ':
                            html += '<h1>' + add(char[i].substring(2)) + '</h1>';
                            break;
                        default:
                            break;
                    }
                } else  {
                    html += '<p>' + add(char[i]) + '</p>';
                }
            }
            return html;
        }

        function add(str) {
            str = str.replace(/\s/g, '&nbsp;');

            return str;
        }
    </script>
</body>

</html>
阅读 870
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题