当字段为空时,val() 返回占位符值,而不是 IE8,9 中的实际值.下面显示的

val() returns Placeholder value instead of the actual value in IE8,9 when the field is empty

本文关键字:字段 IE8 显示 val 返回 占位符      更新时间:2023-09-26

位符属性在Firefox中工作正常,但如果在字段为空时调用val(),则返回占位符值而不是文本中的实际值。

JSFiddle - http://jsfiddle.net/Jrfwr/2/

<input id="tlt" type="text" placeholder="Enter Title" />

JSCode

function placeHolderFallBack() {
   if ("placeholder" in document.createElement("input")) {
       return;
   }
   else {
       $('[placeholder]').focus(function () {
           var input = $(this);
           if (input.val() == input.attr('placeholder')) {
               input.val('');
               input.removeClass('placeholder');
           }
       }).blur(function () {
           var input = $(this);
           if (input.val() == '' || input.val() == input.attr('placeholder')) {
               input.addClass('placeholder');
               input.val(input.attr('placeholder'));
           }
       }).blur();
       $('[placeholder]').parents('form').submit(function () {
           $(this).find('[placeholder]').each(function () {
               var input = $(this);
               if (input.val() == input.attr('placeholder')) {
                   input.val('');
               }
           })
       });
   }
}

你可以覆盖val()方法,但我不喜欢这样做:D

我写了一个简单的pVal()函数来完成这项工作

$.fn.pVal = function(){
    var $this = $(this),
        val = $this.eq(0).val();
    if(val == $this.attr('placeholder'))
        return '';
    else
        return val;
}
$(function(){
    alert($('input').val())
    alert($('input').pVal())
});​

http://jsfiddle.net/W7JKt/3/

在 JSFiddle 代码中,您可以在 BUTTON CLICK 事件中获取文本框的值...检查文本框的当前值是否等于占位符的代码在 FORM SUBMIT 事件中执行。

所以......问题是BUTTON的CLICK事件在FORM的SUBMIT事件之前执行。

此代码显示了如何获取正确值的示例

希望有帮助。

它与HTML 5有关。请参阅此文章。

http://www.cssnewbie.com/cross-browser-support-for-html5-placeholder-text-in-forms/