清除div内任何输入值的简单方法?

Posted

技术标签:

【中文标题】清除div内任何输入值的简单方法?【英文标题】:Simple way to clear the value of any input inside a div? 【发布时间】:2010-12-02 18:27:49 【问题描述】:

有没有一种简单的方法来迭代一个元素中的子元素,比如一个 div,如果它们是 any 类型的输入(收音机、选择、文本、隐藏...),则清除他们的价值?

编辑以添加指向example solution code. 的链接非常感谢 Guffa 和其他受访者!我从中学到了!

【问题讨论】:

【参考方案1】:

卡里姆的回答效果很好。使用 jQuery,我相信它会变成这样:

$("#myDiv").each(function()
   if($(this).type == "input")
      $(this).val('');
);

其实想想,你也可以试试:

$("#myDiv input").val('');//myDiv is your Div name

【讨论】:

我在这个页面中已经有了一些 Scriptaculous 效果。在 jQuery 中也加载会产生冲突吗? 您可以使用以下内容来避免冲突:添加 jQuery.noConflict();到页面顶部,并在调用 jQuery 函数时用单词 jQuery 替换每个 '$'。更多信息:docs.jquery.com/Using_jQuery_with_Other_Libraries 感谢 TTG!我现在会调查这个!1【参考方案2】:

我想你想清除所有的孩子,而不仅仅是直接的孩子,所以它必须是递归的。由于不同的输入元素以不同的方式清除,因此您必须检查它们的类型,以便知道如何处理它们。我想您也想清除 textareas,但保持按钮不变:

function clearChildren(element) 
   for (var i = 0; i < element.childNodes.length; i++) 
      var e = element.childNodes[i];
      if (e.tagName) switch (e.tagName.toLowerCase()) 
         case 'input':
            switch (e.type) 
               case "radio":
               case "checkbox": e.checked = false; break;
               case "button":
               case "submit":
               case "image": break;
               default: e.value = ''; break;
            
            break;
         case 'select': e.selectedIndex = 0; break;
         case 'textarea': e.innerhtml = ''; break;
         default: clearChildren(e);
      
   

通过引用元素来调用它:

clearChildren(document.getElementById('IdOfTheDiv'));

编辑: 忘记选择...

编辑 2: 一些更正:childNodes.length,处理没有 tagName 和大写 tagName 值的元素。

【讨论】:

很好的假设需要它来处理孩子的孩子,但是你不需要递归来抓取后代节点。 感谢您的回复!!我正在尝试实现这一点并且有一个奇怪的症状。简单的测试表格没有明显的效果。如果我收到打印元素的警报,我会得到 [object HTMLDivElement](好..)如果我得到 alert() 来打印 element.childNodes 它有 [object nodeLIst](再次好)但是如果我得到 alert() 来回显该值for() 中的 i 永远不会触发,所以它似乎不会遍历节点?代码如下: function clearChildren(element) for (var i = 0; i 将 for (var i = 0; i 啊,它必须是 case 'INPUT': not case 'input': w00t!1 正在工作,谢谢!!! @crescentfresh:是的,你不需要递归。实际上你永远不会这样做,总是有不同的方法来解决它,但它适用于嵌套元素。 :)【参考方案3】:

哦,男孩,这将是 jQuery 的单行代码:

$(':input:not(:button)', div).val([])

如果没有 jQuery,您必须考虑 &lt;select&gt; 字段、文本字段、密码字段和单选框/复选框字段:

function clearFields(container) 
    var selects = container.getElementsByTagName('select');

    for(var i=0, len=selects.length; i < len; i++) 
        selects[i].selectedIndex = -1;
    

    var fields = container.getElementsByTagName('input');
    for(var i=0, len=fields.length; i < len; i++) 
        var field = fields[i];
        switch(field.type)
        
            case 'radio':
            case 'checkbox':
                field.checked = false;
                break;

            case 'text':
            case 'password':
            case 'hidden':
                field.value = ''
        
    

    var fields = container.getElementsByTagName('textarea');
    for(var i=0, len=fields.length; i < len; i++) 
        fields[i].value = ''
    

【讨论】:

jQuery 解决方案不处理复选框或单选按钮,它会清除按钮的文本...【参考方案4】:

使用 JQuery 非常简单:

$('#myDiv').children().find('input,select').each(function()
   $(this).val('');
);

我们可以在“find”调用中放置尽可能多的标签。

【讨论】:

不错的...只是想知道您是否可以在没有孩子的情况下做到这一点()?例如: $('#myDiv').find('input,select').each(function() $(this).val(''); );【参考方案5】:

荣誉,哈雷什!取消选中复选框的小补充。 (使用 true 来检查所有。)

$('#myDiv').children().find('input,select').each(function()

$(this).val('');
$(this).attr('checked',false);

);

【讨论】:

【参考方案6】:
$('#div_id input[type=textbox], #div_id select, #div_id textarea').val(''); 
$('#div_id input[type=radio], #div_id input[type=checkbox]').prop('checked', false);

用于 jquery。

【讨论】:

【参考方案7】:

使用以下代码清除所有类型的输入表单元素值

function clear_form_elements(id_name) 
  jQuery("#"+id_name).find(':input').each(function() 
    switch(this.type) 
        case 'password':
        case 'text':
        case 'textarea':
        case 'file':
        case 'select-one':       
            jQuery(this).val('');
            break;
        case 'checkbox':
        case 'radio':
            this.checked = false;
    
  );

【讨论】:

【参考方案8】:

这是一个旧帖子,但有人可以看到它。

function clearFields(divElement) 
    var ancestor = document.getElementById(divElement),
    descendents = ancestor.getElementsByTagName('*');

    var i, e, d;
    for (i = 0; i < descendents.length; ++i) 
        if (descendents[i].tagName.toLowerCase() == 'input')
            switch (descendents[i].type)
                case 'text':
                case 'password':
                case 'color':
                case 'date':
                case 'email':
                case 'month':
                case 'number':
                case 'range':
                case 'search':
                case 'tel':
                case 'time':
                case 'url':
                case 'week':
                    descendents[i].value = '';
                    break;

                case 'radio':
                case 'checkbox':
                    descendents[i].checked = false;
            
        
        else if (descendents[i].tagName.toLowerCase() == 'select')
            descendents[i].selectedIndex = 0;
        
       

并使用它:

clearFields ('divName');

当然你可以添加更多的元素来休息它

【讨论】:

以上是关于清除div内任何输入值的简单方法?的主要内容,如果未能解决你的问题,请参考以下文章

清除浮动的方法

访问html表单JavaScript中文本输入字段值的最简单方法?

CSS清除浮动使父级元素展开的三个方法

在 HTML (Java) 中查找值的快速方法

判断输入的内容(汉字英文字符数字)简单方法

关于清除浮动的几种方法