javascript - 从数据量较大的textarea中删除某些文本

标签 javascript html

我使用 HTML 和 Javascript 制作了一个基本的 XML 格式化程序。我想为此添加一个删除功能。基本上,我希望能够删除一个条目,但不清除或损坏任何其他数据。

<contact
<!--John Doe-->
 first_name="John"
 last_name="Doe"
 contact_type="sip"
 account_id="104"
 subscribe_to="sip:104@10.10.1.24"
 has_voicemail="1"
 can_monitor="1"
>
<numbers>
 <number dial="1064" dial_prefix="" label="Extension" />
 <number dial="555-0123" dial_prefix="718" label="Work Line" primary="1" />

我的想法是找到包含 John Doe 的联系人标签并从 <contact 中删除至</numbers>

是否可以使用“indexOf()”通过包含某些信息来删除该组。

上下文:我向 plunkr 添加了一个演示。这获取表单数据并将其导出到文本区域

http://run.plnkr.co/plunks/b9QKZ7KZP0IlcyeCTTc9/

最佳答案

我想你可以尝试其他方法。

  1. 创建一些 Javascript 对象来保存数据。
  2. 向该文本区域呈现对象。
  3. 添加/删除数据时,先操作对象,然后重新呈现。

代码看起来像

//Contact list.
var contacts = [];

// Contact class.
function Contact() {
    ...
    this.name = "";
    this.numbers = [];// numbers
    ...
}

Contact.prototype.toString = function(){
    return "<contact name=\"" + this.name + ...;
};

// Add new Contact
function addContact(params) {

    var contact = new Contact();
    // set properties
    // contact.name = name;
    contacts.push(contact);
    showContacts();
}

// Add new Contact
function deleteContact(name) {

    for (var i = contacts.length-1; i >= 0; i--) {
        if (contacts[i].name == name) {
            contacts.splice(i, 1);
            return;
        }
    }
}

// present contacts
function showContacts(){
    var text = "";
    for(var c in contacts){
        text += c.toString();
    }
    textarea.value = text;
}

// other functions like addNumber etc.

代码会变得有点复杂,但更加清晰和灵活。

关于javascript - 从数据量较大的textarea中删除某些文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17465554/

相关文章:

javascript - 当它不是静态的时候,你如何突出显示键入的文本?

javascript - let 和 const 循环遍历集合有什么区别?

javascript - jQuery 错误地导致悬停

javascript - HTML5 获取圆弧终点的坐标

javascript - Safari上的OnHover HTML5音频

javascript - 添加内容并在主体上 float 外屏

php - 如何使用 href 提交表单?

javascript - 移动 safari 不能专注于 textarea

php - 我无法做到,所以数据存储在 mysql 数据库中

android - 无法在 Android 上播放音频 - Sencha Touch SDK 工具 2.0.0