V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
zilili
V2EX  ›  程序员

前端代码编辑器 ACE 的代码如何提交给后端?并转为 Linux 编码格式

  •  
  •   zilili · 2019-03-03 14:54:22 +08:00 · 1185 次点击
    这是一个创建于 2085 天前的主题,其中的信息可能已经有所发展或是发生改变。

    前端小白-.- 将 ace 代码编辑器放到了 form 表单内.希望提交表单的时候将用户的代码也一起提交,然后存放起来.

    html

    <form id='job_form' name='job_form' method="post">
             <pre id="code" class="ace_editor" style="min-height:400px">
              <textarea class="ace_text-input"></textarea>
             </pre>
    </form>
    

    js

    editor = ace.edit("code");
    editor.setTheme("ace/theme/" + theme);
    editor.session.setMode("ace/mode/" + language);
    等等一些基础配置.
    
    

    当将 form 提交时,代码框内的内容并不会,一起被提交过去.

    后来尝试使用隐藏的 pre textarea 来同步更新内容.配置如下

    editor.getSession().on('change', function(e) {
            var script_val =editor.getValue();//获取内容
            $("#script_content").val(script_val)
    

    虽然可以提交过去了,但是文本本身的\r\n 等也保留了 然后再调用由这个文本生成的脚本的时候就会出现语法错误.

    请问,如何解决?

    nfroot
        1
    nfroot  
       2019-03-03 17:59:06 +08:00
    在你的前端或者后端做一个替换
    \r\n 成为\n
    既然你是前端,那你应该\r\n 也是字符吧,用处理字符的 js 处理它,不会就百度。
    zilili
        2
    zilili  
    OP
       2019-03-03 22:37:09 +08:00 via Android
    @nfroot 嗯,已经解决了,谢谢,刚开始不知道是什么原因🌚生成的脚本,不能用,我以为其他接口有问题呢…查了半天查到是这里…以为是编码之类的,后来搜到是替换,就在后端替换成\n 了,我是后端…
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1970 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 00:27 · PVG 08:27 · LAX 16:27 · JFK 19:27
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.