/*! * copyright c by zhangxinxu 2012-02-06 * jquery.placeholder.js placeholder屬性模擬插件 * v1.0 2012-02-06 create * v1.2 2012-12-20 兼容IE10下IE6-IE7,同時jQuery1.4.*版本 * v1.3 2013-06-14 label元素margin/padding無效問題 * 使用:<input id="test" placeholder="測試" /> *<script src="jquery1.7.1-min.js"></script> *<script src="jquery.placeholder.js"></script> *<script> *$(function() { * $("#test").placeholder(); *}); *</script> */ (function($, undefined) { $.fn.placeholder = function(options) { var defaults = { labelMode: false, labelStyle: {}, labelAlpha: false, labelAcross: false }; var params = $.extend({}, defaults, options || {}); //方法 var funLabelAlpha = function(elementEditable, elementCreateLabel) { if (elementEditable.val() === "") { elementCreateLabel.css("opacity", 0.4).html(elementEditable.data("placeholder")); } else { elementCreateLabel.html(""); } }, funPlaceholder = function(ele) { // 爲了向下兼容jQuery 1.4 if (document.querySelector) { return $(ele).attr("placeholder"); } else { // IE6, 7 var ret; ret = ele.getAttributeNode("placeholder"); // Return undefined if nodeValue is empty string return ret && ret.nodeValue !== "" ? ret.nodeValue : undefined; } }; $(this).each(function() { var element = $(this), isPlaceholder = "placeholder" in document.createElement("input"), placeholder = funPlaceholder(this); // 三種狀況打醬油 // ① 沒有placeholder屬性值 // ② value模擬,同時是支持placeholder屬性的瀏覽器 // ③ label模擬,可是無需跨瀏覽器兼容,同時是支持placeholder屬性的瀏覽器 if (!placeholder || (!params.labelMode && isPlaceholder) || (params.labelMode && !params.labelAcross && isPlaceholder)) { return; } // 存儲,由於有時會清除placeholder屬性 element.data("placeholder", placeholder); // label模擬 if (params.labelMode) { var idElement = element.attr("id"), elementLabel = null; if (!idElement) { idElement = "placeholder" + Math.random(); element.attr("id", idElement); } // 狀態初始化 elementLabel = $('<label for="'+ idElement +'"></label>').css($.extend({ lineHeight: "1.3", position: "absolute", color: "graytext", cursor: "text", marginLeft: element.css("marginLeft"), marginTop: element.css("marginTop"), paddingLeft: element.css("paddingLeft"), paddingTop: element.css("paddingTop") }, params.labelStyle)).insertBefore(element); // 事件綁定 if (params.labelAlpha) { // 若是是爲空focus透明度改變交互 element.bind({ "focus": function() { funLabelAlpha($(this), elementLabel); }, "input": function() { funLabelAlpha($(this), elementLabel); }, "blur": function() { if (this.value === "") { elementLabel.css("opacity", 1).html(placeholder); } } }); //IE6~8不支持oninput事件,須要另行綁定 if (!window.screenX) { element.get(0).onpropertychange = function(event) { event = event || window.event; if (event.propertyName == "value") { funLabelAlpha(element, elementLabel); }; } } // 右鍵事件 elementLabel.get(0).oncontextmenu = function() { element.trigger("focus"); return false; } } else { //若是是單純的value交互 element.bind({ "focus": function() { elementLabel.html(""); }, "blur": function() { if ($(this).val() === "") { elementLabel.html(placeholder); } } }); } // 內容初始化 if (params.labelAcross) { element.removeAttr("placeholder"); } if (element.val() === "") { elementLabel.html(placeholder); } } else { // value模擬 element.bind({ "focus": function() { if ($(this).val() === placeholder) { $(this).val(""); } $(this).css("color", ""); }, "blur": function() { if ($(this).val() === "") { $(this).val(placeholder).css("color", "graytext"); } } }); // 初始化 if (element.val() === "") { element.val(placeholder).css("color", "graytext"); } } }); return $(this); }; })(jQuery);