JQuery Placeholder - Input提示信息

JQuery Placeholder

Placeholder属性是HTML5为Input添加的,在Input上提供一个占位符,文字形式展示输入文字预期值的提示信息。

如:这里写图片描述

需要使用:placeholdr.js
内容:

/**
 * @name placeHolder
 * @class 跨浏览器placeHolder,对于不支持原生placeHolder的浏览器,通过value或插入span元素两种方案模拟
 * @param {Object} obj 要应用placeHolder的表单元素对象
 * @param {Boolean} span 是否采用悬浮的span元素方式来模拟placeHolder,默认值false,默认使用value方式模拟
 */
 //执行
jQuery(function(){
    jQuery(':input[placeholder]').each(function(index, element) {
        placeHolder(element,true);
    }); 
});
function placeHolder(obj, span) {
    if (!obj.getAttribute('placeholder')) return;
    var imitateMode = span===true?true:false;
    var supportPlaceholder = 'placeholder' in document.createElement('input');
    if (!supportPlaceholder) {
    var defaultValue = obj.getAttribute('placeholder');
    var type = obj.getAttribute('type');
    if (!imitateMode) {
        obj.onfocus = function () {
            (obj.value == defaultValue) && (obj.value = '');
            obj.style.color = '';
        }
        obj.onblur = function () {
            if (obj.value == defaultValue) {
                obj.style.color = '';
            } else if (obj.value == '') {
                obj.value = defaultValue;
                obj.style.color = '#ACA899';
            }
        }
        obj.onblur();
    } else {
        var placeHolderCont = document.createTextNode(defaultValue);
        var oWrapper = document.createElement('span');
        oWrapper.style.cssText = 'position:absolute; color:#ACA899; display:inline-block; overflow:hidden;';
        oWrapper.className = 'wrap-placeholder';
        oWrapper.style.fontFamily = getStyle(obj, 'fontFamily');
        oWrapper.style.fontSize = getStyle(obj, 'fontSize');
        oWrapper.style.marginLeft = parseInt(getStyle(obj, 'marginLeft')) ? parseInt(getStyle(obj, 'marginLeft')) + 3 + 'px' : 3 + 'px';
        oWrapper.style.marginTop = parseInt(getStyle(obj, 'marginTop'))!=0 ? getStyle(obj, 'marginTop'): 0 + 'px';
        oWrapper.style.paddingLeft = getStyle(obj, 'paddingLeft');
        oWrapper.style.width = (obj.offsetWidth - parseInt((getStyle(obj, 'marginLeft')=="auto"?0:(getStyle(obj, 'marginLeft')))))==0?100:(obj.offsetWidth - parseInt((getStyle(obj, 'marginLeft')=="auto"?0:(getStyle(obj, 'marginLeft'))))) + 'px';
        oWrapper.style.height = obj.offsetHeight==0?34:obj.offsetHeight + 'px';
        oWrapper.style.lineHeight = obj.nodeName.toLowerCase()=='textarea'? '':(obj.offsetHeight==0?34:obj.offsetHeight) + 'px';
        oWrapper.appendChild(placeHolderCont);
        obj.parentNode.insertBefore(oWrapper, obj);
        oWrapper.onclick = function () {
            obj.focus();
        };
        //绑定input或onpropertychange事件,ie9中删除时无法触发此事件
        if (typeof(obj.oninput)=='object') {
            obj.addEventListener("input", changeHandler, false);
            obj.onpropertychange = changeHandler;
            obj.onkeyup = delHandler;
        } else {
            obj.onpropertychange = changeHandler;
            obj.onkeyup = delHandler;
        }
        function changeHandler() {
            oWrapper.style.display = obj.value != '' ? 'none' : 'inline-block';
        }
        function delHandler(e){//监听del、backspace、ctrl+x
            var e = e || window.event;
            if(e.keyCode == 8 || e.keyCode == 46 || (event.ctrlKey&&e.keyCode == 88)){
                oWrapper.style.display = obj.value != '' ? 'none' : 'inline-block';
            }
        }
        /**
         * @name getStyle
         * @class 获取样式
         * @param {Object} obj 要获取样式的对象
         * @param {String} styleName 要获取的样式名
         */
        function getStyle(obj, styleName) {
            var oStyle = null;
            if (obj.currentStyle)
                oStyle = obj.currentStyle[styleName];
            else if (window.getComputedStyle)
                oStyle = window.getComputedStyle(obj, null)[styleName];
                return oStyle;
            }
        }
    }
}

使用

<input type="text" name="userName" id="userName" placeholder="用户名"/>
<input type="password" name="userPassWord" id="userPassWord" placeholder="密码" />
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据引用\[1\]中的代码,这是一个使用jQuery动态生成输入框的插件。在初始化输入框DOM结构时,会生成一个包含输入框和错误提示的容器。输入框的类型由参数type指定,错误提示信息由参数placeholder指定。如果调用插件时使用了高版本的jQuery,可能会出现错误,因为$.browser这个API在jQuery1.9版本开始被废除了,所以会报错"Cannot read property 'msie' of undefined" \[2\]。 如果你想调用这个插件并设置错误提示信息,可以按照引用\[3\]中的示例代码进行操作。首先,使用$("#username").CreateInput({...})来生成输入框,其中type指定输入框的类型,placeholder指定错误提示信息。然后,可以通过$("#username").data('CreateInput')来获取插件实例,然后使用setValue方法来设置输入框的值。 希望这个回答对你有帮助! #### 引用[.reference_title] - *1* *3* [jQuery输入框插件](https://blog.csdn.net/aolra0914/article/details/102068905)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [jquery输入框邮箱下拉智能提示](https://blog.csdn.net/weixin_42113552/article/details/117872544)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值