<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>网站前端,web前端,前端脚本,前端优化&#124;时代前端 &#187; 总结</title>
	<atom:link href="http://www.52shidai.com/tag/%e6%80%bb%e7%bb%93/feed" rel="self" type="application/rss+xml" />
	<link>http://www.52shidai.com</link>
	<description>网站前端研究中心</description>
	<lastBuildDate>Thu, 02 Feb 2012 03:36:54 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.1</generator>
		<item>
		<title>前端开发经验小结</title>
		<link>http://www.52shidai.com/seo/184.html</link>
		<comments>http://www.52shidai.com/seo/184.html#comments</comments>
		<pubDate>Thu, 04 Mar 2010 07:13:10 +0000</pubDate>
		<dc:creator>admin</dc:creator>
				<category><![CDATA[SEO]]></category>
		<category><![CDATA[前端]]></category>
		<category><![CDATA[总结]]></category>

		<guid isPermaLink="false">http://52shidai.com/?p=184</guid>
		<description><![CDATA[xml文件尽量以utf-8编码，gb2312有些字是存储不了的，如?,就算能存也需要转换，比较麻烦，utf-8也符合国际规范 CSS中:hover这个伪类，如果放在:visited前面则会失效 &#60;a&#62;标签如果没有href属性，所有对它的css的伪类如:hover均失效 js文件中用document.wirte(“&#60;script language=&#8217;javascript&#8217; src=&#8217;” + file + “&#8216;&#62;&#60;/” + “script&#62;”形式的引用，其file相对路径均为引用该js的html的路径。 如：a.htm 引用x\b.js,b.js引用x\c.js,则file应该为x\c.js而不是相对b.js的直接路径c.js，而css中的@import,url()引用不存在这个问题 在页面中，有时talbe的宽设置为100%右边也会留下一个滚动条的空白，请设置&#60;body style=”overflow:auto”&#62; 对于常用的图片不要用img标签，使用&#60;span&#62;&#60;a&#62;并用css指定其背景和宽高，对于做动态的（移上去变背景），使用&#60;a&#62;最好，不需要额外编写代码，只要利用伪类:hover就好了，使用css好处是一次改变全部改变，这点可以很好的利用在换皮肤的应用中 @font-face { font-family:comic; src:url(http://valid_url/some_font_file.eot); } 定义一种在本地没有的字体名称，调用&#60;span style=”font-family:comic;font-size:18pt&#62;aa&#60;/span&#62; 几个CSS div { overflow: hidden;text-overflow:ellipsis; } td { vertical-align : middle; } 要强制溢出发生并且应用 ellipsis 值，作者必须设置对象的 white-space 属性值为 nowrap 。 假如没有换行机会(例如，对象容器的宽度是狭窄的，而内有很长的没有合理断行的文本)，没有应用 nowrap 也有可能溢出。 为了使 ellipsis 值被应用，此属性必须被设置到具有不可视区域的对象。最好的选择是设置 overflow 属性为 hidden。 firefox的document.createElement不支持内容里有HTML标签,也不支持innerText，但是支持innerHTML,可以用innerHTML指定其内容 .net控件里DropDownList在firefox下的宽度不着色，需要直接定义style=&#8217;width:10px;&#8217; firefox中css的cursor不支持hand,使用pointer代替 [...]]]></description>
			<content:encoded><![CDATA[<p>xml文件尽量以utf-8编码，gb2312有些字是存储不了的，如?,就算能存也需要转换，比较麻烦，utf-8也符合国际规范<br />
CSS中:hover这个伪类，如果放在:visited前面则会失效<br />
&lt;a&gt;标签如果没有href属性，所有对它的css的伪类如:hover均失效<br />
js文件中用document.wirte(“&lt;script language=&#8217;javascript&#8217; src=&#8217;” + file + “&#8216;&gt;&lt;/” + “script&gt;”形式的引用，其file相对路径均为引用该js的<a href="http://52shidai.com/archives/tag/html">html</a>的路径。</p>
<p>如：a.htm 引用x\b.js,b.js引用x\c.js,则file应该为x\c.js而不是相对b.js的直接路径c.js，而css中的@import,url()引用不存在这个问题</p>
<p>在页面中，有时talbe的宽设置为100%右边也会留下一个滚动条的空白，请设置&lt;body style=”overflow:auto”&gt;<br />
对于常用的图片不要用img标签，使用&lt;span&gt;&lt;a&gt;并用css指定其背景和宽高，对于做动态的（移上去变背景），使用&lt;a&gt;最好，不需要额外编写代码，只要利用伪类:hover就好了，使用css好处是一次改变全部改变，这点可以很好的利用在换皮肤的应用中<br />
@font-face {<br />
font-family:comic;<br />
src:url(<a href="http://valid_url/some_font_file.eot">http://valid_url/some_font_file.eot</a>);<br />
}<br />
定义一种在本地没有的字体名称，调用&lt;span style=”font-family:comic;font-size:18pt&gt;aa&lt;/span&gt;<br />
几个CSS<br />
div { overflow: hidden;text-overflow:ellipsis; }<br />
td { vertical-align : middle; }<br />
要强制溢出发生并且应用 ellipsis 值，作者必须设置对象的 white-space 属性值为 nowrap 。<br />
假如没有换行机会(例如，对象容器的宽度是狭窄的，而内有很长的没有合理断行的文本)，没有应用 nowrap 也有可能溢出。<br />
为了使 ellipsis 值被应用，此属性必须被设置到具有不可视区域的对象。最好的选择是设置 overflow 属性为 hidden。<br />
firefox的document.createElement不支持内容里有HTML标签,也不支持innerText，但是支持innerHTML,可以用innerHTML指定其内容<br />
.net控件里DropDownList在firefox下的宽度不着色，需要直接定义style=&#8217;width:10px;&#8217;<br />
firefox中css的cursor不支持hand,使用pointer代替<br />
iframe里的滚动条需要在iframe标签里设置style=&#8217;overflow:hidden&#8217;,不能仅仅在body里设置，在firefox会有问题<br />
在onpropertychange事件时，注意使用event.propertyName对属性改变事件过滤，在设置本事件时，其实已经改变了onpropertychange这个属性，所以会自动的执行一次<br />
js5.6里的对XSL的支持版本较低，如document函数就不支持<br />
slice函数比直接循环获取数组片断慢<br />
nextSibling获得下一个对象时，需要注意，两个节点间不要有空格，否则很容易获取不到正确得对象<br />
CreateTextFile在有中文时必须指定第三个参数为true,否则不能写入中文，表现为Write写时报错<br />
保存中文文本时使用ADODB.stream,不使用fso,因为FSO不支持utf-8格式</p>
<h2  class="related_post_title">您可能感兴趣的文章</h2><ul class="related_post"><li><a href="http://www.52shidai.com/seo/187.html" title="Web 前端优化最佳实践之 内容篇">Web 前端优化最佳实践之 内容篇</a></li><li><a href="http://www.52shidai.com/javascript/jquery/90.html" title="Jquery 常用方法经典总结">Jquery 常用方法经典总结</a></li></ul>]]></content:encoded>
			<wfw:commentRss>http://www.52shidai.com/seo/184.html/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Jquery 常用方法经典总结</title>
		<link>http://www.52shidai.com/javascript/jquery/90.html</link>
		<comments>http://www.52shidai.com/javascript/jquery/90.html#comments</comments>
		<pubDate>Sun, 07 Feb 2010 02:18:00 +0000</pubDate>
		<dc:creator>admin</dc:creator>
				<category><![CDATA[jQuery]]></category>
		<category><![CDATA[常用]]></category>
		<category><![CDATA[总结]]></category>
		<category><![CDATA[方法]]></category>

		<guid isPermaLink="false">http://52shidai.com/?p=90</guid>
		<description><![CDATA[1、关于页面元素的引用 通过jquery的$()引用元素包括通过id、class、元素名以及元素的层级关系及dom或者xpath条件等方法，且返回的对象为jquery对象（集合对象），不能直接调用dom定义的方法。 2、jQuery对象与dom对象的转换 只有jquery对象才能使用jquery定义的方法。注意dom对象和jquery对象是有区别的，调用方法时要注意操作的是dom对象还是jquery对象。 普通的dom对象一般可以通过$()转换成jquery对象。 如：$(document.getElementById(“msg”))则为jquery对象，可以使用jquery的方法。 由于jquery对象本身是一个集合。所以如果jquery对象要转换为dom对象则必须取出其中的某一项，一般可通过索引取出。 如：$(“#msg”)[0]，$(“div”).eq(1)[0]，$(“div”).get()[1]，$(“td”)[5]这些都是dom对象，可以使用dom中的方法，但不能再使用Jquery的方法。 以下几种写法都是正确的： 复制代码 代码如下: $(“#msg”).html(); $(“#msg”)[0].innerHTML; $(“#msg”).eq(0)[0].innerHTML; $(“#msg”).get(0).innerHTML; 3、如何获取jQuery集合的某一项 对于获取的元素集合，获取其中的某一项（通过索引指定）可以使用eq或get(n)方法或者索引号获取，要注意，eq返回的是jquery对象，而get(n)和索引返回的是dom元素对象。对于jquery对象只能使用jquery的方法，而dom对象只能使用dom的方法，如要获取第三个&#60;div&#62;元素的内容。有如下两种方法： 复制代码 代码如下: $(“div”).eq(2).html(); //调用jquery对象的方法 $(“div”).get(2).innerHTML; //调用dom的方法属性 4、同一函数实现set和get Jquery中的很多方法都是如此，主要包括如下几个： $(“#msg”).html(); //返回id为msg的元素节点的html内容。 $(“#msg”).html(“&#60;b&#62;new content&#60;/b&#62;”); //将“&#60;b&#62;new content&#60;/b&#62;” 作为html串写入id为msg的元素节点内容中,页面显示粗体的new content $(“#msg”).text(); //返回id为msg的元素节点的文本内容。 $(“#msg”).text(“&#60;b&#62;new content&#60;/b&#62;”); //将“&#60;b&#62;new content&#60;/b&#62;” 作为普通文本串写入id为msg的元素节点内容中,页面显示&#60;b&#62;new content&#60;/b&#62; $(“#msg”).height(); //返回id为msg的元素的高度 $(“#msg”).height(“300&#8243;); //将id为msg的元素的高度设为300 $(“#msg”).width(); //返回id为msg的元素的宽度 $(“#msg”).width(“300&#8243;); //将id为msg的元素的宽度设为300 $(“input”).val(“); //返回表单输入框的value值 $(“input”).val(“test”); //将表单输入框的value值设为test $(“#msg”).click(); //触发id为msg的元素的单击事件 [...]]]></description>
			<content:encoded><![CDATA[<p>1、关于页面元素的引用<br />
通过jquery的$()引用元素包括通过id、class、元素名以及元素的层级关系及dom或者xpath条件等<span class='wp_keywordlink_affiliate'><a href="http://www.52shidai.com/tag/%e6%96%b9%e6%b3%95" title="查看 方法 中的全部文章" target="_blank">方法</a></span>，且返回的对象为jquery对象（集合对象），不能直接调用dom定义的<span class='wp_keywordlink_affiliate'><a href="http://www.52shidai.com/tag/%e6%96%b9%e6%b3%95" title="查看 方法 中的全部文章" target="_blank">方法</a></span>。<br />
2、jQuery对象与dom对象的转换<br />
只有jquery对象才能使用jquery定义的<span class='wp_keywordlink_affiliate'><a href="http://www.52shidai.com/tag/%e6%96%b9%e6%b3%95" title="查看 方法 中的全部文章" target="_blank">方法</a></span>。注意dom对象和jquery对象是有区别的，调用方法时要注意操作的是dom对象还是jquery对象。<br />
普通的dom对象一般可以通过$()转换成jquery对象。<br />
如：$(document.getElementById(“msg”))则为jquery对象，可以使用jquery的方法。<br />
由于jquery对象本身是一个集合。所以如果jquery对象要转换为dom对象则必须取出其中的某一项，一般可通过索引取出。<br />
如：$(“#msg”)[0]，$(“div”).eq(1)[0]，$(“div”).get()[1]，$(“td”)[5]这些都是dom对象，可以使用dom中的方法，但不能再使用Jquery的方法。<br />
以下几种写法都是正确的：<br />
复制代码 代码如下:<br />
$(“#msg”).html();<br />
$(“#msg”)[0].innerHTML;<br />
$(“#msg”).eq(0)[0].innerHTML;<br />
$(“#msg”).get(0).innerHTML;</p>
<p>3、如何获取jQuery集合的某一项<br />
对于获取的元素集合，获取其中的某一项（通过索引指定）可以使用eq或get(n)方法或者索引号获取，要注意，eq返回的是jquery对象，而get(n)和索引返回的是dom元素对象。对于jquery对象只能使用jquery的方法，而dom对象只能使用dom的方法，如要获取第三个&lt;div&gt;元素的内容。有如下两种方法：<br />
复制代码 代码如下:<br />
$(“div”).eq(2).html(); //调用jquery对象的方法<br />
$(“div”).get(2).innerHTML; //调用dom的方法属性</p>
<p>4、同一函数实现set和get<br />
Jquery中的很多方法都是如此，主要包括如下几个：<br />
$(“#msg”).html(); //返回id为msg的元素节点的html内容。<br />
$(“#msg”).html(“&lt;b&gt;new content&lt;/b&gt;”);<br />
//将“&lt;b&gt;new content&lt;/b&gt;” 作为html串写入id为msg的元素节点内容中,页面显示粗体的new content<br />
$(“#msg”).text(); //返回id为msg的元素节点的文本内容。<br />
$(“#msg”).text(“&lt;b&gt;new content&lt;/b&gt;”);<br />
//将“&lt;b&gt;new content&lt;/b&gt;” 作为普通文本串写入id为msg的元素节点内容中,页面显示&lt;b&gt;new content&lt;/b&gt;<br />
$(“#msg”).height(); //返回id为msg的元素的高度<br />
$(“#msg”).height(“300&#8243;); //将id为msg的元素的高度设为300<br />
$(“#msg”).width(); //返回id为msg的元素的宽度<br />
$(“#msg”).width(“300&#8243;); //将id为msg的元素的宽度设为300<br />
$(“input”).val(“); //返回表单输入框的value值<br />
$(“input”).val(“test”); //将表单输入框的value值设为test<br />
$(“#msg”).click(); //触发id为msg的元素的单击事件<br />
$(“#msg”).click(fn); //为id为msg的元素单击事件添加函数<br />
同样blur,focus,select,submit事件都可以有着两种调用方法<br />
5、集合处理功能<br />
对于jquery返回的集合内容无需我们自己循环遍历并对每个对象分别做处理，jquery已经为我们提供的很方便的方法进行集合的处理。<br />
包括两种形式：<br />
$(“p”).each(function(i){this.style.color=['#f00','#0f0','#00f'][i]})<br />
//为索引分别为0，1，2的p元素分别设定不同的字体颜色。<br />
$(“tr”).each(function(i){this.style.backgroundColor=['#ccc','#fff'][i%2]})<br />
//实现表格的隔行换色效果<br />
$(“p”).click(function(){alert($(this).html())})<br />
//为每个p元素增加了click事件，单击某个p元素则弹出其内容<br />
6、扩展我们需要的功能<br />
$.extend({<br />
min: function(a, b){return a &lt; b?a:b; },<br />
max: function(a, b){return a &gt; b?a:b; }<br />
}); //为jquery扩展了min,max两个方法<br />
使用扩展的方法（通过“$.方法名”调用）：<br />
alert(“a=10,b=20,max=”+$.max(10,20)+”,min=”+$.min(10,20));<br />
7、支持方法的连写<br />
所谓连写，即可以对一个jquery对象连续调用各种不同的方法。<br />
例如：<br />
$(“p”).click(function(){alert($(this).html())})<br />
.mouseover(function(){alert(&#8216;mouse over event&#8217;)})<br />
.each(function(i){this.style.color=['#f00','#0f0','#00f'][i]});<br />
8、操作元素的样式<br />
主要包括以下几种方式：<br />
$(“#msg”).css(“background”); //返回元素的背景颜色<br />
$(“#msg”).css(“background”,”#ccc”) //设定元素背景为灰色<br />
$(“#msg”).height(300); $(“#msg”).width(“200&#8243;); //设定宽高<br />
$(“#msg”).css({ color: “red”, background: “blue” });//以名值对的形式设定样式<br />
$(“#msg”).addClass(“select”); //为元素增加名称为select的class<br />
$(“#msg”).removeClass(“select”); //删除元素名称为select的class<br />
$(“#msg”).toggleClass(“select”); //如果存在（不存在）就删除（添加）名称为select的class<br />
9、完善的事件处理功能<br />
Jquery已经为我们提供了各种事件处理方法，我们无需在html元素上直接写事件，而可以直接为通过jquery获取的对象添加事件。<br />
如：<br />
$(“#msg”).click(function(){alert(“good”)}) //为元素添加了单击事件<br />
$(“p”).click(function(i){this.style.color=['#f00','#0f0','#00f'][i]})<br />
//为三个不同的p元素单击事件分别设定不同的处理<br />
jQuery中几个自定义的事件：<br />
（1）hover(fn1,fn2)：一个模仿悬停事件（鼠标移动到一个对象上面及移出这个对象）的方法。当鼠标移动到一个匹配的元素上面时，会触发指定的第一个函数。当鼠标移出这个元素时，会触发指定的第二个函数。<br />
//当鼠标放在表格的某行上时将class置为over，离开时置为out。<br />
$(“tr”).hover(function(){<br />
$(this).addClass(“over”);<br />
},<br />
function(){<br />
$(this).addClass(“out”);<br />
});<br />
（2）ready(fn):当DOM载入就绪可以查询及操纵时绑定一个要执行的函数。<br />
$(document).ready(function(){alert(“Load Success”)})<br />
//页面加载完毕提示“Load Success”,不同于onload事件，onload需要页面内容加载完毕（图片等），而ready只要页面html代码下载完毕即触发。与$(fn)等价<br />
（3）toggle(evenFn,oddFn): 每次点击时切换要调用的函数。如果点击了一个匹配的元素，则触发指定的第一个函数，当再次点击同一元素时，则触发指定的第二个函数。随后的每次点击都重复对这两个函数的轮番调用。<br />
//每次点击时轮换添加和删除名为selected的class。<br />
$(“p”).toggle(function(){<br />
$(this).addClass(“selected”);<br />
},function(){<br />
$(this).removeClass(“selected”);<br />
});<br />
（4）trigger(eventtype): 在每一个匹配的元素上触发某类事件。<br />
例如：<br />
$(“p”).trigger(“click”); //触发所有p元素的click事件<br />
（5）bind(eventtype,fn)，unbind(eventtype): 事件的绑定与反绑定<br />
从每一个匹配的元素中（添加）删除绑定的事件。<br />
例如：<br />
$(“p”).bind(“click”, function(){alert($(this).text());}); //为每个p元素添加单击事件<br />
$(“p”).unbind(); //删除所有p元素上的所有事件<br />
$(“p”).unbind(“click”) //删除所有p元素上的单击事件<br />
10、几个实用特效功能<br />
其中toggle()和slidetoggle()方法提供了状态切换功能。<br />
如toggle()方法包括了hide()和show()方法。<br />
slideToggle()方法包括了slideDown()和slideUp方法。<br />
11、几个有用的jQuery方法<br />
$.browser.浏览器类型：检测浏览器类型。有效参数：safari, opera, msie, mozilla。如检测是否ie：$.browser.isie，是ie浏览器则返回true。<br />
$.each(obj, fn)：通用的迭代函数。可用于近似地迭代对象和数组（代替循环）。<br />
如<br />
$.each( [0,1,2], function(i, n){ alert( “Item #” + i + “: ” + n ); });<br />
等价于：<br />
var tempArr=[0,1,2];<br />
for(var i=0;i&lt;tempArr.length;i++){<br />
alert(“Item #”+i+”: “+tempArr[i]);<br />
}<br />
也可以处理json数据，如<br />
$.each( { name: “John”, lang: “JS” }, function(i, n){ alert( “Name: ” + i + “, Value: ” + n ); });<br />
结果为：<br />
Name:name, Value:John<br />
Name:lang, Value:JS<br />
$.extend(target,prop1,propN)：用一个或多个其他对象来扩展一个对象，返回这个被扩展的对象。这是jquery实现的继承方式。<br />
如：<br />
$.extend(settings, options);<br />
//合并settings和options，并将合并结果返回settings中，相当于options继承setting并将继承结果保存在setting中。<br />
var settings = $.extend({}, defaults, options);<br />
//合并defaults和options，并将合并结果返回到setting中而不覆盖default内容。<br />
可以有多个参数（合并多项并返回）<br />
$.map(array, fn)：数组映射。把一个数组中的项目(处理转换后)保存到到另一个新数组中，并返回生成的新数组。<br />
如：<br />
var tempArr=$.map( [0,1,2], function(i){ return i + 4; });<br />
tempArr内容为：[4,5,6]<br />
var tempArr=$.map( [0,1,2], function(i){ return i &gt; 0 ? i + 1 : null; });<br />
tempArr内容为：[2,3]<br />
$.merge(arr1,arr2):合并两个数组并删除其中重复的项目。<br />
如：$.merge( [0,1,2], [2,3,4] ) //返回[0,1,2,3,4]<br />
$.trim(str)：删除字符串两端的空白字符。<br />
如：$.trim(” hello, how are you? “); //返回”hello,how are you? ”<br />
12、解决自定义方法或其他类库与jQuery的冲突<br />
很多时候我们自己定义了$(id)方法来获取一个元素，或者其他的一些js类库如prototype也都定义了$方法，如果同时把这些内容放在一起就会引起变量方法定义冲突，Jquery对此专门提供了方法用于解决此问题。<br />
使用jquery中的jQuery.noConflict();方法即可把变量$的控制权让渡给第一个实现它的那个库或之前自定义的$方法。之后应用Jquery的时候只要将所有的$换成jQuery即可，如原来引用对象方法$(“#msg”)改为jQuery(“#msg”)。<br />
如：<br />
jQuery.noConflict();<br />
// 开始使用jQuery<br />
jQuery(“div p”).hide();<br />
// 使用其他库的 $()<br />
$(“content”).style.display = &#8216;none&#8217;;</p>
<h2  class="related_post_title">您可能感兴趣的文章</h2><ul class="related_post"><li><a href="http://www.52shidai.com/seo/647.html" title="5种必须的方法做好百度优化和排名">5种必须的方法做好百度优化和排名</a></li><li><a href="http://www.52shidai.com/wordpress/460.html" title="wordpress标签wp list authors使用方法详解 ">wordpress标签wp list authors使用方法详解 </a></li><li><a href="http://www.52shidai.com/javascript/jquery/319.html" title="jQuery each()方法的使用方法">jQuery each()方法的使用方法</a></li><li><a href="http://www.52shidai.com/javascript/jquery/105.html" title="jQuery的html()等方法介绍">jQuery的html()等方法介绍</a></li><li><a href="http://www.52shidai.com/seo/184.html" title="前端开发经验小结">前端开发经验小结</a></li><li><a href="http://www.52shidai.com/javascript/jquery/108.html" title="jQuery的html()等方法介绍">jQuery的html()等方法介绍</a></li><li><a href="http://www.52shidai.com/javascript/jquery/102.html" title="jQuery操作select的常用方法">jQuery操作select的常用方法</a></li><li><a href="http://www.52shidai.com/javascript/jquery/81.html" title="jquery 常用操作方法">jquery 常用操作方法</a></li></ul>]]></content:encoded>
			<wfw:commentRss>http://www.52shidai.com/javascript/jquery/90.html/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

