1

首先在这个例子中看到这个例子http://jsfiddle.net/Es5qs/通过保持空格作为分隔符我创建标签,但我想要的是当我在 textbox1 上输入内容时它应该反映为 textbox2 中的标签听到是我的代码,如何我可以这样做吗?

<!DOCTYPE html>
<html>
<head>
<script src="jquery.min.js"></script>
<script src="jquery-ui.js"></script>

<script>

$(document).ready(function() {

    $("#textBox").keyup(function() {

        $("#message").val(this.value);
    });


});

$(document).ready(function() {

  //The demo tag array
  var availableTags = [
    {value: 1, label: 'tag1'},
    {value: 2, label: 'tag2'},
    {value: 3, label: 'tag3'}];

  //The text input
  var input = $("input#text");

  //The tagit list
  var instance = $("<ul class=\"tags\"></ul>");

  //Store the current tags
  //Note: the tags here can be split by any of the trigger keys
  //      as tagit will split on the trigger keys anything passed  
  var currentTags = input.val();

  //Hide the input and append tagit to the dom
  input.hide().after(instance);

  //Initialize tagit
  instance.tagit({
    tagSource:availableTags,
    tagsChanged:function () {

      //Get the tags            
      var tags = instance.tagit('tags');
      var tagString = [];

      //Pull out only value
      for (var i in tags){
        tagString.push(tags[i].value);
      }

      //Put the tags into the input, joint by a ','
      input.val(tagString.join(','));
    }
  });

  //Add pre-loaded tags to tagit
  instance.tagit('add', currentTags);
});
</script>
</head>
<body>
    <div>
        TextBox 1 : <input type="textbox" id="textBox"></input>
        TextBox 2 : <input type="text" id="message" name="tags"/></input>

    </div>
</body>
</html>
4

1 回答 1

2

jsfiddle 中的演示。主要思想是每次查看整个字符串并简单地重新创建所有元素。这使您免于重复检查等。只要您不想处理大量文本,性能就无关紧要。

我也交换keypresskeydown以捕获退格键。此外,它在每个键上执行,而不仅仅是在空间上。在 keydown 监听器内部:

    tags = this.value.split(/\s+/);
    $(".target").html(""); //clear
    $.each(tags, function (ind, tag) {
        $(".target").append("<a href='#' class='tag'>" + tag + "</a>");
    });

首先,第一个文本框中的输入按空格分隔。正则表达式也匹配连续的空格。这种方式human being仍然只创建两个标签。接下来,清除目标之前的标签。最后,我们遍历所有可用标签并为它们创建链接元素。

注意:我没有改变您创建这些标签的方式。我强烈建议切换到类似$(".target").append($("<a href='#' class='tag'>").text(tag));. 这会转义输入,因此用户不能通过包含 HTML 标记来破坏站点。例如,尝试输入<b>jsfiddle 演示会发生什么。

于 2013-08-10T06:35:44.177 回答