标准兼容HTML5输入框提示信息的插件iHolder_v0.1.06.21.2014_预览版
由于版面限制,简单说下,详细的内容及在线预览、预览版压缩包,见这里
http://levi.cg.am/archives/3507
为什么说是标准兼容:
因为大多数placeholder插件是这样兼容的
点击输入框,提示信息消失;而离开输入框后,若文字为空,则展示提示信息
而这次我要实现的目的在于让IE6-9实现和chrome、firefox一样:
点击输入框后,提示信息不会立即消失,当敲下键盘按键的时候,提示信息消失;当删除文字内容为空的时候,展示提示信息
目前此插件为预览版,希望大家能够多多提意见,正式版,下周见
1. [代码][JavaScript]代码
;(function($) {
$(function() {
if ('placeholder' in document.createElement('input')) {
return this;
}
$(document).on('holder mousedown keydown keyup', 'input, textarea', function(e) {
var $this = $(e.target);
switch(e.type) {
case 'holder':
var tips = $this.attr('placeholder');
if (!tips.length) return false;
if (!$this.val().length) {
$this.val(tips).addClass('placeholder').data({'holder': 1, 'tips': tips});
} else {
$this.data({'holder': 0, 'tips': tips});
}
break;
case 'mousedown':
if (!!$this.data('holder')) {
var $pwd = $this.data('pwd'),
$inp = $this.clone().insertAfter($this).data({
'holder': 1,
'tips': $this.data('tips')
}).focus();
$pwd && $inp.data('pwd', $pwd) && $pwd.data('tar', $inp);
$this.remove();
return false;
}
case 'keydown':
if (!!$this.data('holder')) {
var $pwd = $this.data('pwd');
if (!$pwd) {
$this.val('').removeClass('placeholder').data('holder', 0);
} else {
$pwd.show().focus();
$this.hide();
}
}
break;
case 'keyup':
if (!$this.val().length && $this.data('holder') != undefined) {
var tips = $this.data('tips'), $tar = $this.data('tar'), _rel = (!$tar && !!tips);
(function(par) {http://www.enterdesk.com/special/shouhui/
this.val(tips).addClass('placeholder').data('holder', 1).show().trigger('mousedown');
!par && $this.hide();手绘图片
}).call(_rel ? $this : $tar, _rel);
}
break;
}
});
$('[placeholder]:password').each(function() {
var $this = $(this), tips = $this.attr('placeholder'), $inp;
if (tips.length) {
$inp = $('<input>', {
'type': 'text',
'class': $this.attr('class'),
'style': $this.attr('style'),
'placeholder': tips,
'rel': 'pwdholder'
}).insertAfter($this).data('pwd', $this);
$this.data({'tar': $inp, 'holder': 0, 'tips': tips});
($this.val().length ? $inp : $this)['hide']();
}
});
$('input, textarea').not(':radio, :checkbox, :hidden, :button, :submit,
:file, :password').filter('[placeholder]').trigger('holder');
});
})(jQuery);
标准兼容HTML5输入框提示信息的插件iHolder_v0.1.06.21.2014_预览版的更多相关文章
- HTML5 CSS3 经典案例:无插件拖拽上传图片 (支持预览与批量) (二)
转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/31513065 上一篇已经实现了这个项目的整体的HTML和CSS: HTML5 C ...
- 发布 vscode 插件 Cnblogs Client For VSCode 预览版
为了方便大家使用 vscode 发布博文,我们做了一个小插件,今天发布预览版,欢迎大家试用并反馈问题与建议. 插件的英文名称是 Cnblogs Client For VSCode,简称是 vscode ...
- JQuery插件:图片上传本地预览插件,改进案例一则。
/* *名称:图片上传本地预览插件 v1.1 *作者:周祥 *时间:2013年11月26日 *介绍:基于JQUERY扩展,图片上传预览插件 目前兼容浏览器(IE 谷歌 火狐) 不支持safari *插 ...
- 基于HTML5和JSP实现的图片Ajax上传和预览
本文对如何实现使用Ajax提交"multipart/form"格式的表单数据,已经如何在图片上传之前,在浏览器上进行预览.使用的主要相关技术HTML5的FILE API,XMLHt ...
- Vim安装插件支持 MarkDown 语法、实时预览等
使用 markdown-preview.vim 插件可以实时通过浏览器预览 markdown 文件 使用该插件需要 vim 支持py2/py3 安装 使用 vim-plug: 在 .vimrc 或 i ...
- vue项目使用vue-photo-preview插件实现点击图片放大预览和移动
官方链接: http://npm.taobao.org/package/vue-photo-preview # 安装 npm install vue-photo-preview --save # 引入 ...
- js图片预览插件,不涉及上传
小小的几十行代码,很牛逼,很实用. 支持多个图片的预览,只要new多个对象就行了. html如下 <!-- zhouxiang www.zhou-xiang.com --> <!DO ...
- html5 图片上传,支持图片预览、压缩、及进度显示,兼容IE6+及标准浏览器
以前写过上传组件,见 打造 html5 文件上传组件,实现进度显示及拖拽上传,兼容IE6+及其它标准浏览器,对付一般的上传没有问题,不过如果是上传图片,且需要预览的话,就力有不逮了,趁着闲暇时间,给上 ...
- JS图片上传预览插件制作(兼容到IE6)
其实,图片预览功能非常地常见.很意外,之前遇到上传图片的时候都不需要预览,也一直没有去实现过.现在手上的项目又需要有图片预览功能,所以就动手做了一个小插件.在此分享一下思路. 一.实现图片预览的一些方 ...
随机推荐
- Solidworks拖动装配体的时候物资动力有什么用
Solidworks物资动力就是模拟真实的场景,你在拖动或旋转零件的时候会和周围的零件碰撞,有相互力的作用. 1 标准拖动 2 碰撞检查 3 选择物资动力(零件上面的黑白相间小圆表示物体重心) ...
- Wireshark网络分析实战笔记(三)基本信息统计工具的使用方法
Capture File Properties:获取网络中数据包的整体信息 用法:Statistics菜单条下Capture File Properties选项 Protocol Hierarchy: ...
- vuex mapState使用
<template> <div> {{count}} <button @click="handleIncrease">+5</button ...
- 【转载】ASP.NET之旅--深入浅出解读IIS架构
在学习Asp.net时,发现大多数作者都是站在一个比较高的层次上讲解Asp.Net. 他们耐心. 细致地告诉你如何一步步拖放控件. 设置控件属性.编写 CodeBehind代码,以实现某个特定的功能. ...
- 17:不重复整数提取NoRepeatNum
题目描述 输入一个int型整数,按照从右向左的阅读顺序,返回一个不含重复数字的新的整数. 输入描述:输入一个int型整数 输出描述:按照从右向左的阅读顺序,返回一个不含重复数字的新的整数 输入例子: ...
- C语言 结构体作为函数的参数
1)使用结构体变量作为函数的参数 使用结构体变量作为函数的实参时,采用的是值传递,会将结构体变量所占内存单元的内容全部顺序传递给形参,形参必须是同类型的结构体变量 demo: # include &l ...
- caffe2--------ImportError: No module named past.builtins
whale@sea:~/anaconda2/lib/python2.7/site-packages$ python Python 2.7.14 |Anaconda custom (64-bit)| ( ...
- warning: mysql-community-libs-5.7.11-1.el7.x86_64.rpm: Header V3 DSA/SHA1 Signature, key ID 5072e1f5
1.错误描写叙述 [root@ mysql]# rpm -ivh mysql-community-libs-5.7.11-1.el7.x86_64.rpm warning: mysql-communi ...
- MySQL5.7.18 备份、Mysqldump,mysqlpump,xtrabackup,innobackupex 全量,增量备份,数据导入导出
粗略介绍冷备,热备,温暖,及Mysqldump,mysqlpump,xtrabackup,innobackupex 全量,增量备份 --备份的目的 灾难恢复:意外情况下(如服务器宕机.磁盘损坏等)对损 ...
- 理解Linux系统负荷(WDCP系统后台参数之一)
一.查看系统负荷 如果你的网站很卡,可能是因为服务器很慢,,你或许想查看一下,它的工作量是否太大了. 在Linux系统中,我们一般使用uptime命令查看(w命令和top命令也行).(另外,它们在苹果 ...