img属性alt,不会打×,不提示图片说明文字,只提示参数错误

html的img标签alt的兼容性问题,一些机器是能出现提示,一些机器就不会出现提示,这到底是什么原因_百度知道
html的img标签alt的兼容性问题,一些机器是能出现提示,一些机器就不会出现提示,这到底是什么原因
html的img标签alt的兼容性问题,一些机器是能出现提示,一些机器就不会出现提示,这到底是什么原因
我有更好的答案
alt属性不属于兼容性问题!alt属性,并不是给浏览器看的, 而是给搜索引擎看的!浏览器只是显示图片而已!而,对于搜索引擎来说, 因为看不懂图片内容是什么,给一个alt属性给图片进行一个文字说明,从而让搜索引擎一个判断, 你这图片到底是干什么的!所以, 无需在意这个属性!
为您推荐:
其他类似问题
兼容性的相关知识
换一换
回答问题,赢新手礼包
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。其他模块可以等到需要使用的时候才加载5
时间: 13:56:50
&&&&web前端面试笔试题+优化&&&&前端是庞大的,包括HTML、CSS、Javascript、Image、Flash等等各种各样的资源。前端优化是复杂的,针对方方面面的资源都有不同的方式。那么,前端优化的目的是什么1.从用户角度而言,优化能够让页面加载得更快、对用户的操作响应得更及时,能够给用户提供更为友好的体验。2.从服务商角度而言,优化能够减少页面请求数、或者减小请求所占带宽,能够节省可观的资源。总之,恰当的优化不仅能够改善站点的用户体验并且能够节省相当的资源利用。前端优化的途径有很多,按粒度大致可以分为两类,第一类是页面级别的优化,例如HTTP请求数、脚本的无阻塞加载、内联脚本的位置优化等;第二类则是代码级别的优化,例如Javascript中的DOM操作优化、CSS选择符优化、图片优化以及HTML结构优化等等。另外,本着提高投入产出比的目的,后文提到的各种优化策略大致按照投入产出比从大到小的顺序排列。一、页面级优化1.减少HTTP请求数这条策略基本上所有前端人都知道,而且也是最重要最有效的。都说要减少HTTP请求,那请求多了到底会怎么样呢?首先,每个请求都是有成本的,既包含时间成本也包含资源成本。一个完整的请求都需要经过DNS寻址、与服务器建立连接、发送数据、等待服务器响应、接收数据这样一个“漫长”而复杂的过程。时间成本就是用户需要看到或者“感受”到这个资源是必须要等待这个过程结束的,资源上由于每个请求都需要携带数据,因此每个请求都需要占用带宽。另外,由于浏览器进行并发请求的请求数是有上限的(具体参见此处),因此请求数多了以后,浏览器需要分批进行请求,因此会增加用户的等待时间,会给用户造成站点速度慢这样一个印象,即使可能用户能看到的第一屏的资源都已经请求完了,但是浏览器的进度条会一直存在。减少HTTP请求数的主要途径包括:(1).从设计实现层面简化页面如果你的页面像百度首页一样简单,那么接下来的规则基本上都用不着了。保持页面简洁、减少资源的使用时最直接的。如果不是这样,你的页面需要华丽的皮肤,则继续阅读下面的内容。(2).合理设置HTTP缓存缓存的力量是强大的,恰当的缓存设置可以大大的减少HTTP请求。以有啊首页为例,当浏览器没有缓存的时候访问一共会发出78个请求,共600多K数据(如图1.1),而当第二次访问即浏览器已缓存之后访问则仅有10个请求,共20多K数据(如图1.2)。(这里需要说明的是,如果直接F5刷新页面的话效果是不一样的,这种情况下请求数还是一样,不过被缓存资源的请求服务器是304响应,只有Header没有Body,可以节省带宽)怎样才算合理设置?原则很简单,能缓存越多越好,能缓存越久越好。例如,很少变化的图片资源可以直接通过HTTPHeader中的Expires设置一个很长的过期头;变化不频繁而又可能会变的资源可以使用Last-Modifed来做请求验证。尽可能的让资源能够在缓存中待得更久。关于HTTP缓存的具体设置和原理此处就不再详述了,有兴趣的可以参考下列文章:HTTP1.1协议中关于缓存策略的描述FiddlerHTTPPerformance中关于缓存的介绍(3).资源合并与压缩如果可以的话,尽可能的将外部的脚本、样式进行合并,多个合为一个。另外,CSS、Javascript、Image都可以用相应的工具进行压缩,压缩后往往能省下不少空间。(4).CSSSprites合并CSS图片,减少请求数的又一个好办法。(5).InlineImages&&&&1&&&&&&&&使用data:URLscheme的方式将图片嵌入到页面或CSS中,如果不考虑资源管理上的问题的话,不失为一个好办法。如果是嵌入页面的话换来的是增大了页面的体积,而且无法利用浏览器缓存。使用在CSS中的图片则更为理想一些(6).LazyLoadImage这条策略实际上并不一定能减少HTTP请求数,但是却能在某些条件下或者页面刚加载时减少HTTP请求数。对于图片而言,在页面刚加载的时候可以只加载第一屏,当用户继续往后滚屏的时候才加载后续的图片。这样一来,假如用户只对第一屏的内容感兴趣时,那剩余的图片请求就都节省了。有啊首页曾经的做法是在加载的时候把第一屏之后的图片地址缓存在Textarea标签中,待用户往下滚屏的时候才“惰性”加载。2.将外部脚本置底前文有谈到,浏览器是可以并发请求的,这一特点使得其能够更快的加载资源,然而外链脚本在加载时却会阻塞其他资源,例如在脚本加载完成之前,它后面的图片、样式以及其他脚本都处于阻塞状态,直到脚本加载完成后才会开始加载。如果将脚本放在比较靠前的位置,则会影响整个页面的加载速度从而影响用户体验。解决这一问题的方法有很多,在这里有比较详细的介绍(这里是译文和更详细的例子),而最简单可依赖的方法就是将脚本尽可能的往后挪,减少对并发下载的影响。3.异步执行inline脚本inline脚本对性能的影响与外部脚本相比,是有过之而无不及。首页,与外部脚本一样,inline脚本在执行的时候一样会阻塞并发请求,除此之外,由于浏览器在页面处理方面是单线程的,当inline脚本在页面渲染之前执行时,页面的渲染工作则会被推迟。简而言之,inline脚本在执行的时候,页面处于空白状态。鉴于以上两点原因,建议将执行时间较长的inline脚本异步执行,异步的方式有很多种,例如使用script元素的defer属性(存在兼容性问题和其他一些问题,例如不能使用document.write)、使用setTimeout,此外,在HTML5中引入了WebWorkers的机制,恰恰可以解决此类问题4.LazyLoadJavascript随着Javascript框架的流行,越来越多的站点也使用起了框架。不过,一个框架往往包括了很多的功能实现,这些功能并不是每一个页面都需要的,如果下载了不需要的脚本则算得上是一种资源浪费-既浪费了带宽又浪费了执行花费的时间。目前的做法大概有两种,一种是为那些流量特别大的页面专门定制一个专用的mini版框架,另一种则是LazyLoad。YUI则使用了第二种方式,在YUI的实现中,最初只加载核心模块,其他模块可以等到需要使用的时候才加载5.将CSS放在HEAD中如果将CSS放在其他地方比如BODY中,则浏览器有可能还未下载和解析到CSS就已经开始渲染页面了,这就导致页面由无CSS状态跳转到CSS状态,用户体验比较糟糕。除此之外,有些浏览器会在CSS下载完成后才开始渲染页面,如果CSS放在靠下的位置则会导致浏览器将渲染时间推迟。6.异步请求Callback在某些页面中可能存在这样一种需求,需要使用script标签来异步的请求数据。类似:Javascript:/*Callback函数*/functionmyCallback(info){//dosomethinghere}HTML:scripttype="text/javascript"src="http://abc.com/cb"/scriptcb返回的内容:myCallback('Helloworld!');像以上这种方式直接在页面上写script对页面的性能也是有影响的,即增加了页面首次加载的负担,2&&&&&&&&推迟了DOMLoaded和window.onload事件的触发时机。如果时效性允许的话,可以考虑在DOMLoaded事件触发的时候加载,或者使用setTimeout方式来灵活的控制加载的时机。7.减少不必要的HTTP跳转对于以目录形式访问的HTTP链接,很多人都会忽略链接最后是否带’/',假如你的服务器对此是区别对待的话,那么你也需要注意,这其中很可能隐藏了301跳转,增加了多余请求。具体参见下图,其中第一个链接是以无’/'结尾的方式访问的,于是服务器有了一次跳转。8.避免重复的资源请求这种情况主要是由于疏忽或页面由多个模块拼接而成,然后每个模块中请求了同样的资源时,会导致资源的重复请求二、代码级优化1.Javascript(1).DOMDOM操作应该是脚本中最耗性能的一类操作,例如增加、修改、删除DOM元素或者对DOM集合进行操作。如果脚本中包含了大量的DOM操作则需要注意以下几点:a.HTMLCollection在脚本中document.images、document.forms、getElementsByTagName()返回的都是HTMLCollection类型的集合,在平时使用的时候大多将它作为数组来使用,因为它有length属性,也可以使用索引访问每一个元素。不过在访问性能上则比数组要差很多,原因是这个集合并不是一个静态的结果,它表示的仅仅是一个特定的查询,每次访问该集合时都会重新执行这个查询从而更新查询结果。所谓的“访问集合”包括读取集合的length属性、访问集合中的元素。因此,当你需要遍历HTMLCollection的时候,尽量将它转为数组后再访问,以提高性能。即使不转换为数组,也请尽可能少的访问它,例如在遍历的时候可以将length属性、成员保存到局部变量后再使用局部变量。b.ReflowRepaint除了上面一点之外,DOM操作还需要考虑浏览器的Reflow和Repaint,因为这些都是需要消耗资源的,具体的可以参加以下文章:如何减少浏览器的repaint和reflow?UnderstandingInternetExplorerRenderingBehaviourNotesonHTMLReflow(2).慎用withwith(obj){p=1};代码块的行为实际上是修改了代码块中的执行环境,将obj放在了其作用域链的最前端,在with代码块中访问非局部变量是都是先从obj上开始查找,如果没有再依次按作用域链向上查找,因此使用with相当于增加了作用域链长度。而每次查找作用域链都是要消耗时间的,过长的作用域链会导致查找性能下降。因此,除非你能肯定在with代码中只访问obj中的属性,否则慎用with,替代的可以使用局部变量缓存需要访问的属性。(3).避免使用eval和Function每次eval或Function构造函数作用于字符串表示的源代码时,脚本引擎都需要将源代码转换成可执行代码。这是很消耗资源的操作——通常比简单的函数调用慢100倍以上。eval函数效率特别低,由于事先无法知晓传给eval的字符串中的内容,eval在其上下文中解释要处理的代码,也就是说编译器无法优化上下文,因此只能有浏览器在运行时解释代码。这对性能影响很大。Function构造函数比eval略好,因为使用此代码不会影响周围代码;但其速度仍很慢。此外,使用eval和Function也不利于Javascript压缩工具执行压缩。(4).减少作用域链查找&&&&3&&&&&&&&前文谈到了作用域链查找问题,这一点在循环中是尤其需要注意的问题。如果在循环中需要访问非本作用域下的变量时请在遍历之前用局部变量缓存该变量,并在遍历结束后再重写那个变量,这一点对全局变量尤其重要,因为全局变量处于作用域链的最顶端,访问时的查找次数是最多的。低效率的写法://全局变量varglobalVar=1;functionmyCallback(info){for(vari=100000;i--;){//每次访问globalVar都需要查找到作用域链最顶端,本例中需要访问100000次globalVar+=i;}}更高效的写法://全局变量varglobalVar=1;functionmyCallback(info){//局部变量缓存全局变量varlocalVar=globalVfor(vari=100000;i--;){//访问局部变量是最快的localVar+=i;}//本例中只需要访问2次全局变量globalVar=localV}此外,要减少作用域链查找还应该减少闭包的使用。(5).数据访问Javascript中的数据访问包括直接量(字符串、正则表达式)、变量、对象属性以及数组,其中对直接量和局部变量的访问是最快的,对对象属性以及数组的访问需要更大的开销。当出现以下情况时,建议将数据放入局部变量:a.对任何对象属性的访问超过1次b.对任何数组成员的访问次数超过1次另外,还应当尽可能的减少对对象以及数组深度查找。(6).字符串拼接在Javascript中使用"+"号来拼接字符串效率是比较低的,因为每次运行都会开辟新的内存并生成新的字符串变量,然后将拼接结果赋值给新变量。与之相比更为高效的做法是使用数组的join方法,即将需要拼接的字符串放在数组中最后调用其join方法得到结果。不过由于使用数组也有一定的开销,因此当需要拼接的字符串较多的时候可以考虑用此方法。关于Javascript优化的更详细介绍请参考:WriteEfficientJavascript(PPT)EfficientJavaScript2.CSS选择符在大多数人的观念中,都觉得浏览器对CSS选择符的解析式从左往右进行的,例如#tocA{color:#444;}4&&&&&&&&这样一个选择符,如果是从右往左解析则效率会很高,因为第一个ID选择基本上就把查找的范围限定了,但实际上浏览器对选择符的解析是从右往左进行的。如上面的选择符,浏览器必须遍历查找每一个A标签的祖先节点,效率并不像之前想象的那样高。根据浏览器的这一行为特点,在写选择符的时候需要注意很多事项,有人已经一一列举了,详情参考此处。3.HTML对HTML本身的优化现如今也越来越多的受人关注了,详情可以参见这篇总结性文章。4.Image压缩图片压缩是个技术活,不过现如今这方面的工具也非常多,压缩之后往往能带来不错的效果,具体的压缩原理以及方法在《EvenFasterWebSites》第10章有很详细的介绍,有兴趣的可以去看看。总结本文从页面级以及代码级两个粒度对前端优化的各种方式做了一个总结,这些方法基本上都是前端开发人员在开发的过程中可以借鉴和实践的,除此之外,完整的前端优化还应该包括很多其他的途径,例如CDN、Gzip、多域名、无Cookie服务器等等,由于对于开发人员的可操作性并不强大,在此也就不多叙述了,详细的可以参考Yahoo和Google的这些“金科玉律”。1.Javascript简介HTML是纯静态的的页面,而Javascript让页面有了动态的效果,比如;OA中模块的拖拉所有的浏览器都会内置Javascript的解释器1992年Nombas公司开发出C减减的嵌入式脚本语言。这是最好的HTML页面的脚本语言。Netscape为了扩展其浏览器的功能,开发了一套LiveScript,并与1995年与SUN公司联合把其改名为javascript,它的主要目的是处理一些输入的有效性验证,而之前这个工作是留给perl之类的服务器端语言完成,在以前使用电话线调制解调器(28.8kb/s)的时代,如此慢的与服务器交互,这绝对是一件很痛苦的事情。Javascript的出现,解决了这个问题,因为它的验证是基于客户端的。微软公司早期版本的浏览器仅支持自己的vbscript,但后来不得不加入javascriptIE3中搭载Javascipt的克隆版本,命名为jscript在一次技术会议中,sun,microsoft,netscape公司联合制定了ECMA-Script标准在2005前,网页上提示框,广告越来越多,把javascipt滥用,使javascript背上了大量的罪名。2005年,google公司的网上产品(google地图,gmail,google搜索建议)等使得ajax兴起,而javascript便是ajax最重要的元素之一Javascript有三个部分组成ECMAScriptDOMBOMWEB标准网页主要有三部分组成(结构HTML,XHTML,表现CSS,行为DOM,ECMA)&&&&2.ECMA脚本&&&&Javascript的语法1.2.3.4.区分大小写弱类型变量varage=10varname=”dd”每行结尾的分号可有可无,但建议还是加上注释与java相同&&&&变量变量是通过var关键字来声明的。(Variable)变量的命名规则与java一致5&&&&&&&&注释有三种://&&&&/**/&&&&!----这个只能注释单行&&&&2.1javascript的Helloworld&&&&document.write()是写在文档的最前面&&&&2.2slice()、substring()、subtr&&&&Slice和substring(2,5)指的是从第3为开始,取(5-2)=3个数,其中slice的参数可以为负Substr(2,5)指的是从第3为开始,取5个数。但ECMAscript没有对该方法进行标准化,因此尽量少使用该方法&&&&2.3indexOf()和lastIndexOf(),isNan,typeOf&&&&indexOf(”i”)//从前往后,i在第几位indexOf(”i”,3)可选参数,从第几个字符开始往后找lastIndexOf(”i”)lastIndexOf(”i”,3)//从后往前,i在第几位//从后往前,i在第几位&&&&如果没找到,则返回-1String类型的变量,在Java中,用“”符号表示字符串,用’’表示单个字符。而在javascript中这两种都可以Nan(notanumber)Alert(nan==nan)返回false,因此不推荐使用nan本身,推荐函数isNanAlert(isNanN(“ab”));//返回falsetypeof运算符varstmp=“test”;alert(typeofstmp);//输出stringalert(typeof1);//输出number此外:还有boolean,undefined,object(如果是引用类型或者null值,null值返回object,这其实是ecmascript的一个错误)当声明的变量未初始化的时候,它的值就是undefined.当没有这个变量的时候,typeof变返回的值也是undefined。但是没声明的变量是不能参与计算的。当函数无明确返回值时,返回的也是undefinedFunctiona(){}Alert(a()==undefined)//返回trueAlert(null==undefined)//返回true&&&&2.4数值计算&&&&varmynum1=23.345;varmynum2=45;varmynum3=-34;6&&&&&&&&varmynum4=9e5;varfNumber=123.456;&&&&//科学计数法为9*10五次方&&&&alert(fNumber.toExponential(1));//保留的小数点数1.2e+2alert(fNumber.toExponential(2));//1.23e+2&&&&.5布尔值&&&&varmarried=alert("1."+typeof(married));//Booleanmarried="true";alert("2."+typeof(married));//String&&&&.6类型转换&&&&转换成string类型有三种方式vara=3;varb=a+"";varc=a.toString();vard="student"+a;toString()vara=11;document.write(a.toString(2)+"br");//转成2进制document.write(a.toString(3)+"br");//转成3进制如果不是数值,则转换报错&&&&parseInt()document.write(parseInt("1red6")+"br");//返回1,后面非数值的将全部忽略document.write(parseInt("53.5")+"br");//返回53document.write(parseInt("0xC")+"br");//直接十进制转换12document.write(parseInt("")+"br");//NANdocument.write(parseInt("011",8)+"br");返回9document.write(parseInt("011",10)+"br");//指定为十进制返回11parseFloat()与parseInt()类似&&&&2.7数组&&&&varaMap=newArray("China","USA","Britain");aMap[20]="Korea";alert(aMap.length+""+aMap[10]+""+aMap[20]);//aMap[10]返回undefined&&&&7&&&&&&&&document.write(aMap.join("][")+"br");&&&&//用“][”来连接&&&&varsFruit="apple,pear,peach,orange";varaFruit=sFruit.split(",");varaFruit=["apple","pear","peach","orange"];alert(aFruit.reverse().toString());varaFruit=["pear","apple","peach","orange"];aFruit.sort();varstack=newArray();stack.push("red");stack.push("green");stack.push("blue");document.write(stack.toString()+"br");varvItem=stack.pop();//bluedocument.write(vItem+"br");document.write(stack.toString());//redgreen&&&&2.8if语句&&&&//首先获取用户的一个输入,并用Number()强制转换为数字variNumber=Number(prompt("输入一个5到100之间的数字",""));//第二个参数,用于显示输入框的默认值if(isNaN(iNumber))//判断输入的是否是数字NaN“NotaNumber”//判断输入的数字范围document.write("请确认你的输入正确");elseif(iNumber100||iNumber5)elsedocument.write("你输入的数字是:"+iNumber);document.write("你输入的数字范围不在5和100之间");&&&&2.9switch&&&&iWeek=parseInt(prompt("输入1到7之间的整数",""));switch(iWeek){case1:document.write("Monday");case2:document.write("Tuesday");8&&&&&&&&case3:document.write("Wednesday");case4:document.write("Thursday");case5:document.write("Friday");case6:document.write("Saturday");case7:document.write("Sunday");default:document.write("Error");}&&&&2.10while语句&&&&vari=iSum=0;while(i=100){iSum+=i;i++;}alert(iSum);do.whileforbreakcontinue(与JAVA语法一致)&&&&2.11函数&&&&functionArgsNum(){returnarguments.}document.write(ArgsNum("isaac",25)+"br");document.write(ArgsNum()+"br");document.write(ArgsNum(3)+"br");从这个例子可以看出,方法可以没有参数,也可以没有返回值,但是照样可以传入参数和返回值。&&&&2.12Date对象&&&&varmyDate1=newDate();//运行代码前的时间for(vari=0;i3000000;i++);&&&&9&&&&&&&&varmyDate2=newDate();//运行代码后的时间document.write(myDate2);varoMyDate=newDate();variYear=oMyDate.getFullYear();variMonth=oMyDate.getMonth()+1;//月份是从0开始的variDate=oMyDate.getDate();variDay=oMyDate.getDay();//0为星期日1为星期一functiondisDate(oDate,iDate){varms=oDate.getTime();ms-=iDate*24*60*60*1000;returnnewDate(ms);}varoBeijing=newDate();variNum=100;varoMyDate=disDate(oBeijing,iNum);2.13检测浏览器和操作系统varsUserAgent=navigator.userA//检测Opera、KHTMLvarisOpera=sUserAgent.indexOf("Opera")-1;varisKHTML=sUserAgent.indexOf("KHTML")-1||sUserAgent.indexOf("Konqueror")-1||sUserAgent.indexOf("AppleWebKit")-1;//检测IE、MozillavarisIE=sUserAgent.indexOf("compatible")-1sUserAgent.indexOf("MSIE")-1!isOvarisMoz=sUserAgent.indexOf("Gecko")-1!isKHTML;//检测操作系统varisWin=(navigator.platform=="Win32")||(navigator.platform=="Windows");varisMac=(navigator.platform=="Mac68K")||(navigator.platform=="MacPPC")||(navigator.platform=="Macintosh");varisUnix=(navigator.platform=="X11")!isWin!isMif(isOpera)document.write("Opera");if(isKHTML)document.write("KHTML");if(isIE)document.write("IE");if(isMoz)document.write("Mozilla");if(isWin)document.write("Windows");if(isMac)document.write("Mac");if(isUnix)document.write("Unix");1.13Global对象其实isNan,paraseInt等都是Global对象的方法EncodeURI.因为有效的URI不能包含某些字符,如空格。这个方法就是用于将这个字符转换成UTF-8//前100天//换成毫秒数//计算相差的毫秒数//返回新的时间对象&&&&10&&&&&&&&编码,使浏览器可以接受他们。&&&&Varsuil=“www.oseschool.com/profile/a.html”;Alert(encodeURI(suil));//www.oseschool.com/pro%20file/a.html即将空格编码成%20Eval方法Eval(“alert(‘hi’)”);当解析程序发现eval()时,它将把参数解析成真正的ECMA-script语句,然后插入该语句所在位置。Global除了有内置方法外,还有很多内置的属性:如:undefined,nan,Array,String,Number,Date,RegExp等1.14Math对象Max方法,min方法,ceil,floor,round,sqrt,randomMax(1,2,3);min(1.2,3.4);想取到1~10的数据Math.floor(Math.random()*10+1)2~9的数据Math.floor(Math.random()*9+2);&&&&3.1getElementsByTagName&&&&functionsearchDOM(){//放在函数内,页面加载完成后才用body的onload加载,这时如果把alert这句改成用document.write则会把原内容覆盖掉,因为是后面才执行的varoLi=document.getElementsByTagName("li");//输出长度、标签名称以及某项的文本节点值alert(oLi.length+""+oLi[0].tagName+""+oLi[3].childNodes[0].nodeValue);varoUl=document.getElementsByTagName("ul");varoLi2=oUl[1].getElementsByTagName("li");alert(oLi2.length+""+oLi2[0].tagName+""+oLi2[1].childNodes[0].nodeValue);}bodyonload="searchDOM()"ul客户端语言liHTML/liliJavaScript/liliid="cssLi"CSS/li/ulul服务器端语言11&&&&&&&&liASP.NET/liliJSP/liliPHP/li/ul/body&&&&3.2getElementById&&&&varoLi=document.getElementById("cssLi");oLi.style.backgroundColor="yellow"//输出标签名称以及文本节点值alert(oLi.tagName+""+oLi.childNodes[0].nodeValue);&&&&3.2getElementsByName&&&&alert(document.getElementsByName("a").length);&&&&3.3访问子节点&&&&functionmyDOMInspector(){varoUl=document.getElementById("myList");varDOMString="";if(oUl.hasChildNodes()){varoCh=oUl.childNfor(vari=0;ioCh.i++)DOMString+=oCh[i].nodeName+"\n";}alert(DOMString);}4访问父节点nodeName如果为文本节点,则返回#texttagName如果为文本节点,则返回undefinedfunctionmyDOMInspector(){varmyItem=document.getElementById("myDearFood");alert(myItem.parentNode.tagName);}functionmyDOMInspector(){varmyItem=document.getElementById("myDearFood");varparentElm=myItem.parentNwhile(parentElm.className!="colorful"parentElm!=document.body)parentElm=parentElm.parentN//一路往上找//逐一查找//判断是否有子节点//获取ul标记&&&&12&&&&&&&&alert(parentElm.tagName);}bodyonload="myDOMInspector()"divclass="colorful"ulli糖醋排骨/lili圆笼粉蒸肉/lili泡菜鱼/liliid="myDearFood"板栗烧鸡/lili麻婆豆腐/li/ul/div/body访问兄弟节点functionmyDOMInspector(){varmyItem=document.getElementById("myDearFood");//访问兄弟节点varnextListItem=myItem.nextSvarpreListItem=myItem.previousSalert(nextListItem.tagName+""+preListItem.tagName);}在Firefox中不支持,但是IE中却是支持的。&&&&3.6第一个最后一个子节点&&&&functionnextSib(node){vartempLast=node.parentNode.lastC//判断是否是最后一个节点,如果是则返回nullif(node==tempLast)vartempObj=node.nextS//逐一搜索后面的兄弟节点,直到发现元素节点为止while(tempObj.nodeType!=1tempObj.nextSibling!=null)tempObj=tempObj.nextS//三目运算符,如果是元素节点则返回节点本身,否则返回nullreturn(tempObj.nodeType==1)?tempObj:}functionprevSib(node){vartempFirst=node.parentNode.firstC//判断是否是第一个节点,如果是则返回nullif(node==tempFirst)vartempObj=node.previousS13&&&&&&&&//逐一搜索前面的兄弟节点,直到发现元素节点为止while(tempObj.nodeType!=1tempObj.previousSibling!=null)tempObj=tempObj.previousSreturn(tempObj.nodeType==1)?tempObj:}functionmyDOMInspector(){varmyItem=document.getElementById("myDearFood");//获取后一个元素兄弟节点varnextListItem=nextSib(myItem);//获取前一个元素兄弟节点varpreListItem=prevSib(myItem);alert("后一项:"+((nextListItem!=null)?nextListItem.firstChild.nodeValue:null)+"前一项:"+((preListItem!=null)?preListItem.firstChild.nodeValue:null));}nodeType元素element属性attr文本text注释comments文档document12389&&&&functionshowAttr(){varbtnShowAttr=document.getElementById("btnShowAttr");//演示按钮,有很多属性varattrs=btnShowAttr.for(vari=0;iattrs.i++){varattr=attrs[i];alert('nodeType:'+attr.nodeType);//attribute的nodeType=2alert('attr:'+attr);alert('attr.name:'+attr.name+'='+attr.value);}&&&&functionshowDocument(){alert('nodeType:'+document.nodeType);alert('nodeName:'+document.nodeName);alert(document);}//9&&&&3.7getAttributesetAttribute&&&&functionmyDOMInspector(){//获取图片14&&&&&&&&varmyImg=document.getElementsByTagName("img")[0];//获取图片title属性alert(myImg.getAttribute("title"));}functionchangePic(){//获取图片varmyImg=document.getElementsByTagName("img")[0];//设置图片src和title属性myImg.setAttribute("src","02.jpg");myImg.setAttribute("title","紫荆公寓");}&&&&3.8创建新节点&&&&functioncreateP(){varop=document.createElement("p");varotext=document.createTextNode("HHHHH");op.appendChild(otext);op.setAttribute("style","text-align:center");document.body.appendChild(op);//创建完节点,就马上会影响到下面的操作,比如P的数量就会多1个}&&&&3.9删除节点&&&&需要注意的是标签之间的父子关系!!!functiondeleteP(){varoP=document.getElementsByTagName("p")[0];oP.parentNode.removeChild(oP);}//删除节点&&&&3.10替换节点&&&&functionreplaceP(){15&&&&&&&&varoOldP=document.getElementsByTagName("p")[0];varoNewP=document.createElement("p");oNewP.appendChild(oText);oOldP.parentNode.replaceChild(oNewP,oOldP);}//替换节点//新建节点varoText=document.createTextNode("这是一个感人肺腑的故事");&&&&3.11插入节点&&&&functioninsertP(){varoOldP=document.getElementsByTagName("p")[0];varoNewP=document.createElement("p");oNewP.appendChild(oText);oOldP.parentNode.insertBefore(oNewP,oOldP);}没有insertAfter,但是可以自己写一个functioninsertAfter(newElement,targetElement){varoParent=targetElement.parentNif(oParent.lastChild==targetElement)else之前oParent.insertBefore(newElement,targetElement.nextSibling);}functioninsertP(){varoOldP=document.getElementById("myTarget");varoNewP=document.createElement("p");oNewP.appendChild(oText);insertAfter(oNewP,oOldP);}其实这个也是通过insertBefore原理来实现的//插入节点//新建节点varoText=document.createTextNode("这是一个感人肺腑的故事");oParent.appendChild(newElement);//首先找到目标元素的父元素//则直接用appendChild()加到子元素列表的最后//否则用insertBefore()插入到目标元素的下一个兄弟元素//如果目标元素已经是最后一个子元素了//插入节点//新建节点varoText=document.createTextNode("这是一个感人肺腑的故事");&&&&16&&&&&&&&3.12cloneNode(deepBoolean)&&&&复制并返回当前节点的复制节点,这个复制得到的节点是一个孤立的节点,不在document树中。复制原来节点的属性值,包括ID属性,所以在把这个新节点加到document之前,一定要修改ID属性,以便使它保持唯一。当然如果ID的唯一性不重要可以不做处理。这个方法支持一个布尔参数,当deepBoolean设置true时,复制当前节点的所有子节点,包括该节点内的文本。pid=”mypara”11111/pp=document.getElementById("mypara")pclone=p.cloneNode(true);p.parentNode.appendChild(pclone&&&&3.12文档碎片&&&&functioninsertPs(){varaColors=["red","green","blue","magenta","yellow","chocolate","black","aquamarine","lime","fuchsia","brass","azure","brown","bronze","deeppink","aliceblue","gray","copper","coral","feldspar","orange","orchid","pink","plum","quartz","purple"];varoFragment=document.createDocumentFragment();//创建文档碎片for(vari=0;iaColors.i++){varoP=document.createElement("p");varoText=document.createTextNode(aColors[i]);oP.appendChild(oText);oFragment.appendChild(oP);}document.body.appendChild(oFragment);}//最后一次性添加到页面//将节点先添加到碎片中&&&&3.13innerHTML&&&&functionmyDOMInnerHTML(){varmyDiv=document.getElementById("myTest");alert(myDiv.innerHTML);//直接显示innerHTML的内容&&&&17&&&&&&&&//修改innerHTML,可直接添加代码myDiv.innerHTML="imgsrc='01.jpg'title='情人坡'";}innerHTML可同时显示没有的代码&&&&3.14换皮肤&&&&styletype="text/css".myUL1{color:#0000FF;font-family:Afont-weight:}.myUL2{color:#FF0000;font-family:Georgia,"TimesNewRoman",Times,}/stylescriptlanguage="javascript"functioncheck(){varoMy=document.getElementsByTagName("ul")[0];oMy.className=(oMy.className=="myUL1"?"myUL2":"myUL1");//修改CSS类}/script/headbodyulonclick="check()"class="myUL1"liHTML/liliJavaScript/liliCSS/li/ul/body&&&&4.表格与表单&&&&4.1动态添加行&&&&scriptlanguage="javascript"18&&&&&&&&window.onload=function(){varoTr=document.getElementById("member").insertRow(2);//插入一行varaText=newArray();aText[0]=document.createTextNode("fresheggs");aText[1]=document.createTextNode("W610");aText[2]=document.createTextNode("Nov5th");aText[3]=document.createTextNode("Scorpio");aText[4]=document.createTextNode("1038818");for(vari=0;iaText.i++){varoTd=oTr.insertCell(i);oTd.appendChild(aText[i]);}}/script&&&&4.2修改单元格内容&&&&scriptlanguage="javascript"window.onload=function(){varoTable=document.getElementById("member");oTable.rows[3].cells[4].innerHTML="lost";}/script//修改单元格内容&&&&4.3动态删除&&&&parentElement是IEdom,parentNode是标准DOMscriptlanguage="javascript"window.onload=function(){varoTable=document.getElementById("member");oTable.deleteRow(2);行删除oTable.rows[2].deleteCell(1);}/scriptscriptlanguage="javascript"functionmyDelete(){varoTable=document.getElementById("member");//删除该行19//删除一个单元格,后面的也自动补齐//删除一行,后面的行号自动补齐//指从table中的第2行开始进&&&&&&&&this.parentNode.parentNode.parentNode.removeChild(this.parentNode.parentNode);}window.onload=function(){varoTable=document.getElementById("member");varoTd;//动态添加delete链接for(vari=1;ioTable.rows.i++){oTd=oTable.rows[i].insertCell(5);oTd.innerHTML="ahref='#'delete/a";oTd.firstChild.onclick=myD//添加删除事件}}/script&&&&4.4动态删除列&&&&scriptlanguage="javascript"functiondeleteColumn(oTable,iNum){//自定义删除列函数,即每行删除相应单元格for(vari=0;ioTable.rows.i++)oTable.rows[i].deleteCell(iNum);}window.onload=function(){varoTable=document.getElementById("member");deleteColumn(oTable,2);}/script&&&&4.5控制textarea的字符个数&&&&scriptlanguage="javascript"functionLessThan(oTextArea){//返回文本框字符个数是否符号要求的boolean值returnoTextArea.value.lengthoTextArea.getAttribute("maxlength");}/script&&&&5.BOM模型&&&&浏览器对象模型,可以对浏览器窗口进行访问和操作,使用BOM,开发者可以移动窗口,改变状态栏中的文&&&&20&&&&&&&&本等与页面内容不相关的操作&&&&Window对象&&&&这里可以用window.frames[0]或者用windows.frames[“topFrame”]来引用框架,也可以用topl来代替window属性。Top.frames[0]。window对象可以忽略提供的方法有moveto,moveBy,resizeTo,resizeBy等方法。但尽量避免使用它们,因为会对用户浏览产生影响&&&&Open方法&&&&除了open方法,还有alert,comfirm,prompt方法&&&&21&&&&&&&&状态栏&&&&Settimeout与setInterval&&&&Settimeout下面的代码都是在1秒钟后显示一条警告Settimeout(“alert(‘aa’),1000”);Settimeout(function(){alert(‘aa’);},1000);如果要还未执行的暂停,可调用clearTimeOut()方法Varsi=Settimeout(function(){alert(‘aa’);},1000);clearTimeout(si);&&&&setInterval&&&&22&&&&&&&&History&&&&向后一页window.history.go(-1);等于history.back();向前一页window.history.go(1);等于history.forword();&&&&Document&&&&LastModified,title,URL属性都是比较常用&&&&Location对象&&&&Navigator对象&&&&Screen对象&&&&6.事件&&&&6.1冒泡型事件&&&&scriptlanguage="javascript"functionadd(sText){varoDiv=document.getElementById("display");oDiv.innerHTML+=sT}/script/headbodyonclick="add('bodybr');"divonclick="add('divbr');"ponclick="add('pbr');"ClickMe/p/div23//输出点击顺序&&&&&&&&divid="display"/div/body先执行最里面的p,再往外执行&&&&6.2监听函数&&&&scriptlanguage="javascript"window.onload=function(){varoP=document.getElementById("myP");//找到对象oP.onclick=function(){alert('我被点击了');}}/script/headbodydivpid="myP"ClickMe/p/div/body//设置事件监听函数&&&&Functiona(){}oP.onclick=a这样会先把a函数加载到缓存,不是最佳方案VarA=Function(){}oP.onclick=a这样只有在onclick事件发生的时候,加载该函数&&&&若以上的监听函数,在onclick的时候,需要执行多个函数,那就只能用以下的方法:IE标准:scriptlanguage="javascript"functionfnClick(){alert("我被点击了");oP.detachEvent("onclick",fnClick);}varoP;//声明在函数外,这样就可以两个函数一起使用window.onload=function(){24//点击了一次后删除监听函数&&&&&&&&oP=document.getElementById("myP");//找到对象oP.attachEvent("onclick",fnClick);}/script/headbodydivpid="myP"ClickMe/p/div/body也可以添加多个监听器oP.attachEvent("onclick",fnClick1);oP.attachEvent("onclick",fnClick2);执行顺序为fnClick2-fnClick1但是以上的监听器均为IE中的标准,而符合标准DOM(firefox)的监听器如下oP.addEventListener("click",fnClick1,false);oP.addEventListener("click",fnClick2,false);因此这种方式在Firefox中支持,而在IE中不支持为了兼容性,可这样写if(el.addEventListener){el.addEventListener('click',KindDisableMenu,false);}elseif(el.attachEvent){el.attachEvent('onclick',KindDisableMenu);}第三个参数为useCapture//添加监听函数1//添加监听函数2//添加监听函数1//添加监听函数2//添加监听函数&&&&而useCapture这个参数就是在控制这时候两个click事件的先后顺序。如果是false,那就会使用bubbling,他是从内而外的流程,所以会先执行蓝色元素的click事件再执行红色元素的click事件,如果是true,那就是capture,和bubbling相反是由外而内&&&&25&&&&&&&&6.3事件的类型event.type&&&&IE浏览器中事件对象是window对象的一个属性eventOp.onlick=function(){varo=window.event}而标准DOM中规定event对象必须作为唯一的参数传给事件处理函数Op.onclick=function(oevent){}因此为了兼容两种浏览器,通常采用下面的方法Op.onclick=function(o){If(window.event)//假如不等于空,则为IE浏览器O=window.}scriptlanguage="javascript"functionhandle(oEvent){varoDiv=document.getElementById("display");if(window.event)oEvent=window.if(oEvent.type=="click")elseif(oEvent.type=="mouseover")oDiv.innerHTML+="你移动到我上方了";}window.onload=function(){varoImg=document.getElementsByTagName("img")[0];oImg.onclick=oImg.onmouseover=}/script还有很多鼠标事件//处理兼容性,获得事件对象//检测事件名称&&&&oDiv.innerHTML+="你点击了我";&&&&window.onload=function(){varoImg=document.getElementsByTagName("img")[0];oImg.onmousedown=oImg.onmouseup=oImg.onmouseover=oImg.onmouseout=oImg.onclick=oImg.ondblclick=}//将鼠标事件除了mousemove外都监听&&&&26&&&&&&&&6.4事件的激活元素event.srcElement或者target&&&&}document.onmousedown=TestCwindow.onload=TestC//测试未按下任何键/script/headbodydivid="display"/div/body在IE/Opera中,是window.event,而在Firefox中,是event而事件的对象,在IE中是//IE支持window.event.srcElement,在Firefox中是event.target,而在Opera中则两者都支持。&&&&oTextArea.onkeydown=oTextArea.onkeypress=}e.keyConkeypress是在用户按下并放开任何字母数字键时发生。系统按钮(例如,箭头键和功能键,Shift、Ctrl、Alt、F1、F2)无法得到识别。onkeyup是在用户放开任何先前按下的键盘键时发生。onkeydown是在用户按下任何键盘键(包括系统按钮,如箭头键和功能键)时发生屏蔽鼠标右键第一种方式:scriptlanguage="javascript"functionblock(oEvent){if(window.event)oEvent=window.if(oEvent.button==2)alert("鼠标右键不可用");}document.onmousedown=/script第二种方式:scriptlanguage="javascript"functionblock(oEvent){if(window.event){oEvent=window.oEvent.returnValue=//取消默认事件支持IE}else//监听所有键盘事件oTextArea.onkeyup=&&&&scriptlanguage="javascript"functionhandle(oEvent){if(window.event)oEvent=window.容性,获得事件对象varoTif(oEvent.srcElement)//处理兼容性,获取事件目标oTarget=oEvent.srcE的写法elseoTarget=oEvent.支持的写法alert(oTarget.tagName);//弹出目标的标记名称}window.onload=function(){varoImg=document.getElementsByTagName("img")[0];oImg.onclick=}/scriptevent.buttonscriptlanguage="javascript"functionTestClick(oEvent){varoDiv=document.getElementById("display");if(window.event)oEvent=window.oDiv.innerHTML+=oEvent.//输出button的值//Firefox//处理兼&&&&在IE里面左键是window.event.button=1右键是window.event.button=2中键是window.event.button=4没有按键动作的时候window.event.button=0在Firefox里面左键是event.button=0右键是event.button=2中键是event.button=1没有按键动作的时候event.button=0在Opera7.23/7.54里面鼠标左键是window.event.button=1没有按键动作的时候window.event.button=1右键和中键无法获取键盘事件window.onload=function(){varoTextArea=document.getElementsByTagName("textarea")[0];&&&&27&&&&&&&&varaLi=oUl.childNoEvent.preventDefault();//取消默认事件支持Firefox}document.oncontextmenu=/script6.8伸缩的菜单scriptlanguage="javascript"functionchange(){//通过父元素li,找到兄弟元素ulvaroSecondDiv=this.parentNode.getElementsByTagName("ul")[0];//这里的this就是下面的OA//CSS交替更换来实现显、隐if(oSecondDiv.className=="myHide")oSecondDiv.className="myShow";elseoSecondDiv.className="myHide";}window.onload=function(){varoUl=document.getElementById("listUL");鼠标事件onclickonmouseoveronmousedownonmouseuponmouseoutondblclickdocument事件oncontextmenuwrite键盘事件onmousedownwindow事件onloadtagName出来的都是大写总结《Event详解》DOM常用属性tagNamenodeValuenodeNamenodeTypeparentNodechildNodesfirstChildlastChildnextSibling(IE)previousSibling(IE)onkeydownonkeyuponkeypress}/script}}"LI"aLi[i].getElementsByTagName("ul").length){oA=aLi[i].firstC//找到超链接oA.onclick=//动态添加点击函数//子元素varoA;for(vari=0;iaLi.i++){//如果子元素为li,且这个li有子菜单ulif(aLi[i].tagName==&&&&attributesinnerHTMLstyleclassName方法getElementByIdgetElementsByNamegetElementsByTagNamehasChildNodes()getAttributesetAttributecreateElementcreateTextNodeappendChildremoveChildreplaceChildinsertBeforecloneNodecreateDocumentFragmentdetachEventattachEvent(IE)addEventListener(DOM)event属性typekeyCodesrcElement(IE)target(DOM)button&&&&7.JavaScipt优化和调试7.1错误和异常拼写错误、访问不存在的变量,括号不匹配,等号与赋值声明变量时,要记住局部变量和全局变量的区别&&&&Functionsquare(num){Total=num*R&&&&28&&&&&&&&}Vartotal=50;Varnumber=Square(20);Alert(total);这些代码将不可避免地导致全局变量total的值发生变化。Functionsquare(num){VarTotal=num*R}&&&&7.3调试器&&&&"02/a/liliahref="photo/03.jpg"title="c"onclick="showPic(this);"03/a/liliahref="photo/04.jpg"title="d"onclick="showPic(this);"04/a/liliahref="photo/05.jpg"title="e"onclick="showPic(this);"05/a/li/ulimgid="image"src="photo/01.jpg"alt="myimage"/img/body/htmlReturnfalse指的是把默认的noclick事件取消给其加上cssstylebody{color:#333;background:#margin:1em10%;}a{text-decoration:padding:10color:#c60;}a:link,a:visited{color:#A62020;background-color:#ecd8text-decoration:padding:4px10px4px10border-top:1pxsolid#EEE;border-left:1pxsolid#EEE;border-bottom:1pxsolid#717171;&&&&IE-工具-Intenet选项-高级-禁用调试,显示脚本错误Firefox错误控制台MicrosoftscriptdebuggerVenkmanfirefox的插件&&&&6.4JavaScript优化1.提高JavaScript下载时间。将JavaScript写到同一行2.尽量使用内置函数(因为内置函数是通过C语言编译到浏览器&&&&7.2错误处理&&&&onerrorheadtitleonerror/titlescriptlanguage="javascript"window.onerror=function(){alert("出错啦!");统事件}/script/headbodyonload="nonExistent()"/bodyTry..catchscriptlanguage="javascript"try{alert("thisisanexample");alert(fresheggs);}catch(exception){varsError="";for(variinexception)sError+=i+":"+exception[i]+"\n";alert(sError);}/script//屏蔽系&&&&中的).实例1图片查看器htmlheadtitle/titlescriptfunctionshowPic(obj){varh=obj.getAttribute("href");&&&&document.getElementById("image").setAttribute("src",h);}/script/headbodyh1Snapshots/h1ulliahref="photo/01.jpg"title="a"onclick="showPic(this);"01/a/liliahref="photo/02.jpg"title="b"onclick="showPic(this);return29&&&&&&&&border-right:1pxsolid#717171;}a:hover{color:#821818;background-color:#e2c4c9;padding:5px8px3px12border-top:1pxsolid#717171;border-left:1pxsolid#717171;border-bottom:1pxsolid#EEE;border-right:1pxsolid&&&&#EEE;}ul{margin:0padding:0}li{list-style-type:display:}img{margin:10px0}/style当时现在有个缺陷,就是onclick的事件直接写在了HTML上,分}&&&&离先给ul加上个属性idulid=”img_ul”window.onload=prepareGfunctionprepareGalley(){varimg_ul=document.getElementById("img_ul");varlinks=img_ul.getElementsByTagName("a");&&&&for(vari=0;ilinks.i++){links[i].onclick=function(){showPic(this);}}}&&&&还有一个比这个更NB的写法,由SimonWillison写的functionaddLoadEvent(func){varoldonload=window.if(typeofwindow.onload!='function'){window.onload=&&&&有一个问题,如果onload的函数有多个怎么办?window.onload=prepareGalley1;window.onload=prepareGalley2;显然,这样第一个函数就会被第二个函数覆盖。&&&&}else{window.onload=function(){oldonload();func();}}}&&&&可以这样写&&&&Window.onload=function(){prepareGalley1();prepareGalley2();编写一个方法求一个字符串的字节长度newfunction(s){if(!arguments.length||!s)if(""==s)return0;varl=0;for(vari=0;is.i++){if(s.charCodeAt(i)255)l+=2;elsel++;}alert(l);}("helloworld!");解释document.getElementById("ElementID").style.fontSize="1.5em"设置id为ElementID的元素的字体大小为1.5个相对单位Em为相对长度单位。相对于当前对象内文本的字如何控制alert中的换行alert("hello\nworld");addLoadEvent(prepareGalley1);addLoadEvent(prepareGalley2);&&&&30&&&&&&&&体尺寸。如当前对行内文本的字体尺寸未被人为设置,则相对于浏览器的默认字体尺寸。1em=16px说出3条以上ff和ie的脚本兼容问题按照格式xxxx年xx月xx日xx时xx分xx秒动态显示时间要求不足10的补0scripttype="text/javascript"language="javascript"functiontick(){vard=newDate();vart=function(a){returna10?"0"+a:a;}Clock.innerHTML=d.getFullYear()+"年"+t(d.getMonth()+1)+"月"+t(d.getDate())+"日"+t(d.getHours())+"时"+t(d.getMinutes())+"分"+t(d.getSeconds())+"秒";window.setTimeout("tick()",1000);}window.onload=/script为Array写一个indexof方法bodydivid="Clock"/div/body}编写一个方法去掉一个数组的重复元素Array.prototype.strip=function(){if(this.length2)return[this[0]]||[];vararr=[];for(vari=0;ithis.i++){arr.push(this.splice(i--,1));//将本数组中第一个元素取出放入到数组arr中for(varj=0;jthis.j++){}if(this[j]==arr[arr.length-1]){vararr=[1,2,3,4,5];this.splice(j--,1);//删除本数组中与数组arr中最后一个元素相同的元素}}}}克隆浅复制(影子克隆):只复制对象的基本类型,对象类型,仍属于原来的引用深复制(深度克隆):不紧复制对象的基本类,同时也复制原对象中的对象.就是说完全是新对象产生的alert(arr.indexOf(5));}return-1;Array.prototype.lastIndexOf=function(e){for(vari=this.length-1,j;j=this[i];i--){if(j==e){}}return-1;Array.prototype.indexOf=function(e){for(vari=0,j;j=this[i];i++){if(j==e){}DIV中border、margin和padding的区别和用法边框属性(border)用来设定一个元素的边线外边距属性(margin)是用来设置一个元素所占空间的边缘到相邻元素之间的距离内边距属性(padding)是用来设置元素内容到元素边界的距离IE有children,FF没有;IE有parentElement,FF没有;IE有innerText,outerText,outerHTML,FF没有;IE有数据岛,FF没有;FF有HTMLElement,HTMLDivElement,XMLDocument,DocumentFragment,Node,Event,Element等等,IE没有;IE跟FF创建HttpRequest实例的方法不一样vararr=["abc",85,"abc",85,8,8,1,2,5,4,7,8];alert(arr.strip());&&&&31&&&&&&&&图片存在Object.prototype.Clone=function(){varobjCif(this.constructor==Object)objClone=newthis.constructor();elseobjClone=newthis.constructor(this.valueOf());for(varkeyinthis){if(objClone[key]!=this[key]){if(typeof(this[key])=='object'){objClone[key]=this[key].Clone();}else{objClone[key]=this[key];}}}objClone.toString=this.toSobjClone.valueOf=this.valueOf;returnobjC}兼容IE和FF的换行CSS推荐样式word-wrap:break-overflow:word-wrap是控制换行的。使用break-word时,是将强制换行。中文没有任何问题,英文语句也没问题。但是对于长串的英文,就不起作用。}word-break是控制是否断词的。normal是默认情况,英文单词不被拆开。break-all,是断开单词。在单词到边界时,下个字母自动到下一行。主要解决了长串英文的问题。keep-all,是指Chinese,Japanese,andKorean不断词。即只用此时,不用word-wrap,中文就不会换行了。(英文语句正常。)手型Cursor的兼容IE和FF写法cursor:pointerimg元素的alt和title有什么异同?alt作为图片的替代文字出现,title是图片的解释文字如何提高网页的运行速度内容与形式分离,模块化开发,优化CSSLinux题目:批量删除当前目录下后缀名为.c的文件,如a.c、b.crm*.c}HTML:bodydivid=”right”?/divdivid=”left”?/div/body#left{marin-right:200border-color-left、marin-left、-moz-viewport改写成JavaScript格式border-color-left:borderLeftColormarin-left:marinLeft-moz-viewport:MozViewport用css、html编写一个两列布局的网页,要求右侧宽度为200px,左侧自动扩展。CSS:#right{float:width:200当然不同的浏览器处理方式也会不一样图片不存在只有alt图片既有替代文字,又有解释文字只有title图片没有替代文字,只有解释文字两者都有图片既有替代文字,又有解释文字两者都没有图片既没有替代文字,也没有解释文字只有alt图片的解释文字只有title图片的解释文字两者都有图片的解释文字两者都没有图片既没有替代文字,也没有解释文字&&&&32&&&&&&&&减少页面文档大小尽量减少图片的使用或注意图片的大小,优化图片:格式、质量、图片长宽标志减少响应的次数,用Ajax网址后面加一个“/”按要求写一个简单的ajax示例bodydivid="load"数据正在加载....../divscripttype="text/javascript"varBrowser={/**Browser对象用于检测浏览器,其中用到了IE的条件编译*/isFF:window.navigator.appName.toUpperCase().indexOf("NETSCAPE")!=-1?true:false,isOpera:window.navigator.appName.toUpperCase().indexOf("OPERA")!=-1?true:false};&&&&xml2.XMLHTTP.4.0","Msxml2.XMLHTTP.3.0",+"Msxml2.XMLHTTP.2.6","Msxml2.XMLHTTP","Microsoft.XMLHTTP.1.0","Microsoft.XMLHTTP.1","Microsoft.XMLHTTP"];for(vari=0;iVersion.i++){try{returnnewActiveXObject(Version[i]);}catch(e){}}}}()||}HttpRequest.prototype={send:function(object,url,callback){if(!this.xmlhttp)&&&&Function.prototype.bind=function(object){this.xmlhttp.open(object?"post":"get",url,!!this.asyncvar_this=returnfunction(){_this.apply(object,arguments);}}functionHttpRequest(){this.async=this.cache=this.xmlhttp=function(){if(Browser.isFFwindow.XMLHttpRequest){this.xmlhttp.setRequestHeader("Cache-Control","no-ctry{returnnewXMLHttpRequest();}catch(e){}}elseif(Browser.isIEwindow.ActiveXObject){varVersion=["Msxml2.XMLHTTP.6.0","Msxml2.XMLHTTP.5.0","Msthis.xmlhttp.setRequestHeader("If-Modified-Since","this.xmlhttp.setRequestHeader("Last-Modified","Wed,1Jan:00GMT");this.xmlhttp.setRequestHeader("Expire","0");ache");this.xmlhttp.setRequestHeader("Pragma","no-cache"););if(object)this.xmlhttp.setRequestHeader("content-type","application/x-www-form-urlencoded");if(!this.cache){this.xmlhttp.setRequestHeader("No-Cache","1");&&&&33&&&&&&&&1");}if(!this.callback)this.callback=if(!this.async){if(typeof(this.callback)=="string"){eval(this.callback);}elseif(typeof(this.callback)=="function"){}}}.bind(this);}this.callback(this.xmlhttp);if(typeof(this.callback)=="function"){&&&&}else&&&&}&&&&this.xmlhttp.send(object);this.callback(this.xmlhttp);}}else{this.xmlhttp.onreadystatechange=function(){newif(this.xmlhttp.readyState==4){HttpRequest().send(null,"http://bbs.51js.com/index.php",function(r){if(this.xmlhttp.status==0||this.xmlhttp.status==200){document.getElementById("load").innerHTML=r.responseText.match(/img.*?(?:\/)?/img).join("");});/scriptif(typeof(this.callback)=="string"){/bodyif(this.xmlhttpthis.xmlhttp.abort)this.xmlhttp.abort();}};//ajax类定义结束},abort:function(){&&&&eval(this.callback);IE6、IE7、IE8、Firefox兼容性CSSHACK代码+示例________________________________________整理关于IE6、IE7、IE8、Firefox兼容性CSSHACK问题1.区别IE和非IE浏览器CSSHACK代码#divcss5{background:/*非IE背景蓝色*/background:red\9;/*IE6、IE7、IE8背景红色*/}2.区别IE6,IE7,IE8,FFCSSHACK【区别符号】:「\9」、「*」、「_」【示例】:【说明】:因为IE系列浏览器可读「\9」,而IE6和IE7可读「*」(米字号),另外IE6可辨识「_」(底线),因此可以依照顺序写下来,就会让浏览器正确的读取到自己看得懂得CSS语法,所以就可以有效区分IE各版本和非IE浏览器(像是Firefox、Opera、#divcss5{background:/*Firefox背景变蓝色*/background:red\9;/*IE8背景变红色*/*background:/*IE7背景变黑色*/_background:/*IE6背景变橘色*/}&&&&34&&&&&&&&GoogleChrome、Safari等)。3.区别IE6、IE7、Firefox(EXP1)【区别符号】:「*」、「_」【示例】:#divcss5{background:/*Firefox背景变蓝色*/*background:/*IE7背景变黑色*/_background:/*IE6背景变橘色*/}【说明】:IE7和IE6可读「*」(米字号),IE6又可以读「_」(底线),但是IE7却无法读取「_」,至于Firefox(非IE浏览器)则完全无法辨识「*」和「_」,因此就可以透过这样的差异性来区分IE6、IE7、Firefox4.区别IE6、IE7、Firefox(EXP2)【区别符号】:「*」、「!important」【示例】:#divcss5{background:/*Firefox背景变蓝色*/*background:green!/*IE7背景变绿色*/*background:/*IE6背景变橘色*/}【说明】:IE7可以辨识「*」和「!important」,但是IE6只可以辨识「*」,却无法辨识「!important」,至于Firefox可以读取「!important」但不能辨识「*」因此可以透过这样的差异来有效区隔IE6、IE7、Firefox。5.区别IE7、Firefox【区别符号】:「*」、「!important」【示例】:#divcss5{background:/*Firefox背景变蓝色*/*background:green!/*IE7背景变绿色*/_background:/*IE6背景变橘色*/}&&&&}【说明】:因为Firefox可以辨识「!important」但却无法辨识「*」,而IE7则可以同时看懂「*」、「!important」,因此可以两个辨识符号来区隔IE7和Firefox。6.区别IE6、IE7(EXP1)【区别符号】:「*」、「_」【示例】:#tip{*background:/*IE7背景变黑色*/_background:/*IE6背景变橘色*/}【说明】:IE7和IE6都可以辨识「*」(米字号),但IE6可以辨识「_」(底线),IE7却无法辨识,透过IE7无法读取「_」的特性就能轻松区隔IE6和IE7之间的差异。7.区别IE6、IE7(EXP2)【区别符号】:「!important」【示例】:#divcss5{background:black!/*IE7背景变黑色*/background:/*IE6背景变橘色*/}【说明】:因为IE7可读取「!」但IE6却不行,而CSS的读取步骤是从上到下,因此IE6读取时因无法辨识「!important」而直接跳到下一行读取CSS,所以背景色会呈现橘色。8.区别IE6、Firefox【区别符号】:「_」【示例】:#divcss5{background:/*Firefox背景变黑色*/&&&&【说明】:因为IE6可以辨识「_」(底线),但是Firefox却不行,因此可以透过这样的差异来区隔Firefox和IE6,有效达成CSShack。以上包括了IE6\IE8\IE7\火狐浏览器兼容问题及解决方法。[HTMLCSS]1.Doctype?严格模式与混杂模式-如何触发这两种模式,区分它们有何意义?Doctype声明位于文档中的最前面的位置,处于标签之前。此标签可告知浏览器文档使用哪种HTML或&&&&35&&&&&&&&XHTML规范。该标签可声明三种DTD类型,分别表示严格版本、过渡版本以及基于框架的HTML文档。当浏览器厂商开始创建与标准兼容的浏览器时,他们希望确保向后兼容性。为了实现这一点,他们创建了两种呈现模式:标准模式和混杂模式(quirksmode)。在标准模式中,浏览器根据规范呈现页面;在混杂模式中,页面以一种比较宽松的向后兼容的方式显示。混杂模式通常模拟老式浏览器(比如MicrosoftIE4和NetscapeNavigator4)的行为以防止老站点无法工作。浏览器根据DOCTYPE是否存在以及使用的哪种DTD来选择要使用的呈现方法。如果XHTML文档包含形式完整的DOCTYPE,那么它一般以标准模式呈现。对于HTML4.01文档,包含严格DTD的DOCTYPE常常导致页面以标准模式呈现。包含过渡DTD和URI的DOCTYPE也导致页面以标准模式呈现,但是有过渡DTD而没有URI会导致页面以混杂模式呈现。DOCTYPE不存在或形式不正确会导致HTML和XHTML文档以混杂模式呈现。2.行内元素有哪些?块级元素有哪些?CSS的盒模型?行内元素有:abspanIbemimginputselectstrong块级元素有:divulollidldtddh1h2h3h4?p盒模型:marginborderpaddingwidth3.1.CSS引入的方式有哪些?link和@import的区别是?使用LINK标签&&&&将样式规则写在.css的样式文件中,再以link标签引入。linkrel=stylesheettype="text/css"href="example.css"2.使用@import引入跟link方法很像,但必须放在STYLE.../STYLE中STYLETYPE="text/css"!-@importurl(css/example.css);--/STYLE3.使用STYLE标签将样式规则写在STYLE.../STYLE标签之中。STYLETYPE="text/css"!-body{color:#666;background:#f0f0f0;font-size:12}td,p{color:#c00;font-size:12}--/STYLE4.值2;...}5.使用span/span标记引入样式#000000;"cnwebshow.com/spanspanstyle="font:12px/20px使用STYLE属性将STYLE属性直接加在个别的元件标签里,元件(标签)STYLE="性质(属性)1:设定值1;性质(属性)2:设定&&&&两者区别:加载顺序的差别。当一个页面被加载的时候,link引用的CSS会同时被加载,而@import引用的CSS会等到页面全部被下载完再被加载。@import可以在css中再次引入其他样式表,比如可以创建一个主样式表,在主样式表中再引入其他的样式表,如:&&&&main.css&&&&36&&&&&&&&———————@import“sub1.css”;@import“sub2.css”;这样做有一个缺点,会对网站服务器产生过多的HTTP请求,以前是一个文件,而现在却是两个或更多文件了,服务器的压力增大,浏览量大的网站还是谨慎使用。CSS选择符有哪些?哪些属性可以继承?优先级算法如何计算?内联和important哪个优先级高?&&&&4.&&&&?通配选择符?*{sRules}?类型选择符?E{sRules}td{font-size:14width:120}?属性选择符?E[attr]{sRules}E[attr=value]{sRules}E[attr~=value]{sRules}E[attr|=value]{sRules}h其他模块可以等到需要使用的时候才加载5{color:}/*所有具有title属性的h对象*/span[class=demo]{color:}div[speed="fast"][dorun="no"]{color:}a[rel~="copyright"]{color:}?包含选择符?E1E2{sRules}tabletd{font-size:14}?子对象选择符?E1E2{sRules}divullip{font-size:14}?选择符#ID?{IDsRules}?类选择符E.className?{sRules}?选择符分组?E1,E2,E3{sRules}?伪类及伪对象选择符?E:Pseudo-Classes{sRules}(Pseudo-Classes)[:link:hover:active:visited:focus:first-child:first:left:right:lang]E:Pseudo-Elements{sRules}(Pseudo-Elements)[:first-letter:first-line:before:after]可以继承的有:font-sizefont-familycolor不可继承的一般有:borderpaddingmarginbackground-colorwidthheight等============================关于CSSspecificityCSS的specificity特性或称非凡性,它是衡量一个衡量CSS值优先级的一个标准,既然作为标准,就具有一套相关的判定规定及计算方式,specificity用一个四位的数字串(CSS2是三位)来表示,更像四个级别,值从左到右,左面的最大,一级大于一级,数位之间没有进制,级别之间不可超越。在多个选择符应用于同一个元素上那么Specificity值高的最终获得优先级。使用!important可以改变优先级别为最高,其次是style对象,然后是idclasstag,另外在同级样式按照申明的顺序后出现的样式具有高优先级。5.前端页面由哪三层构成,分别是什么?作用是什么?网页分成三个层次,即:结构层、表示层、行为层。&&&&37&&&&&&&&网页的结构层(structurallayer)由HTML或XHTML之类的标记语言负责创建。标签,也就是那些出现在尖括号里的单词,对网页内容的语义含义做出了描述,但这些标签不包含任何关于如何显示有关内容的信息。例如,P标签表达了这样一种语义:“这是一个文本段。”网页的表示层(presentationlayer)由CSS负责创建。CSS对“如何显示有关内容”的问题做出了回答。网页的行为层(behaviorlayer)负责回答“内容应该如何对事件做出反应”这一问题。这是Javascript语言和DOM主宰的领域。6.7.css的基本语句构成是?你做的页面在哪些流览器测试过?这些浏览器的内核分别是什么?经常遇到的浏览器的兼容性有选择器{属性1:值1;属性2:值2;}哪些?怎么会出现?解决方法是什么?IE内核浏览器:360,傲游,搜狗,世界之窗,腾讯TT非IE内核浏览器:firefoxoperasafarichrome8.如何居中一个浮动元素?设置容器的浮动方式为相对定位,然后确定容器的宽高,比如宽500高300的层,然后设置层的外边距。div{Width:500height:300Margin:-150px00-250position:left:50%;top:50%;}9.有没有关注HTML5和CSS3?如有请简单说一些您对它们的了解情况!HTML5标签的改变:header,footer,dialog,aside,figure,section等IE9以上开始支持CSS3实现圆角,阴影,对文字加特效,增加了更多的CSS选择器。10.11.如果让你来制作一个访问量很高的大型网站,你会如何来管理所有CSS文件、JS与图片?你对前端界面工程师这个职位是怎么样理解的?它的前景会怎么样?&&&&以下为Web前端开发笔试题集锦之Javascript篇,移步HTML/CSS篇1,判断字符串是否是这样组成的,第一个必须是字母,后面可以是字母、数字、下划线,总长度为5-20varreg=/^[a-zA-Z][a-zA-Z_0-9]{4,19}$/;reg.test("a1a__a1a__a1a__a1a__");2,截取字符串abcdefg的efgvarstr="abcdefg";if(/efg/.test(str)){varefg=str.substr(str.indexOf("efg"),3);alert(efg);}3,判断一个字符串中出现次数最多的字符,统计这个次数//将字符串的字符保存在一个hashtable中,key是字符,value是这个字符出现的次数varstr="abcdefgaddda";varobj={};for(vari=0,l=str.l;i++){varkey=str[i];if(!obj[key]){obj[key]=1;}else{obj[key]++;}}&&&&38&&&&&&&&/*遍历这个hashtable,获取value最大的key和value*/varmax=-1;varmax_key="";for(keyinobj){if(maxobj[key]){max=obj[key];max_key=}}alert("max:"+max+"max_key:"+max_key);4,IE与FF脚本兼容性问题(1)window.event:表示当前的事件对象,IE有这个对象,FF没有,FF通过给事件处理函数传递事件对象(2)获取事件源IE用srcElement获取事件源,而FF用target获取事件源(3)添加,去除事件IE:element.attachEvent(“onclick”,function)element.detachEvent(“onclick”,function)FF:element.addEventListener(“click”,function,true)element.removeEventListener(“click”,function,true)(4)获取标签的自定义属性IE:div1.value或div1[“value”]FF:可用div1.getAttribute(“value”)(5)document.getElementByName()和document.all[name]IE;document.getElementByName()和document.all[name]均不能获取div元素FF:可以(6)input.type的属性IE:input.type只读FF:input.type可读写(7)innerTexttextContentouterHTMLIE:支持innerText,outerHTMLFF:支持textContent(8)是否可用id代替HTML元素IE:可以用id来代替HTML元素FF:不可以这里只列出了常见的,还有不少,更多的介绍可以参看JavaScript在IE浏览器和Firefox浏览器中的差异总结5,规避javascript多人开发函数重名问题(1)可以开发前规定命名规范,根据不同开发人员开发的功能在函数前加前缀(2)将每个开发人员的函数封装到类中,调用的时候就调用类的函数,即使函数重名只要类名不重复就ok6,javascript面向对象中继承实现javascript面向对象中的继承实现一般都使用到了构造函数和Prototype原型链,简单的代码如下:functionAnimal(name){this.name=&&&&39&&&&&&&&}Animal.prototype.getName=function(){alert(this.name)}functionDog(){};Dog.prototype=newAnimal("Buddy");Dog.prototype.constructor=Dvardog=newDog();7,FF下面实现outerHTMLFF不支持outerHTML,要实现outerHTML还需要特殊处理思路如下:在页面中添加一个新的元素A,克隆一份需要获取outerHTML的元素,将这个元素append到新的A中,然后获取A的innerHTML就可以了。!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"htmlxmlns="http://www.w3.org/1999/xhtml"headmetahttp-equiv="Content-Type"content="text/charset=gb2312"/title获取outerHMTL/titlestylediv{background:#0000FF;width:100height:100}span{background:#00FF00;width:100height:100}p{background:#FF0000;width:100height:100}/style/headbodydivid="a"spanSPAN/spanDIV/divspanSPAN/spanpP/pscripttype="text/javascript"functiongetOuterHTML(id){varel=document.getElementById(id);varnewNode=document.createElement("div");document.appendChild(newNode);varclone=el.cloneNode(true);newNode.appendChild(clone);alert(newNode.innerHTML);document.removeChild(newNode);}getOuterHTML("a");/script/body/html8,编写一个方法求一个字符串的字节长度假设:&&&&40&&&&&&&&一个英文字符占用一个字节,一个中文字符占用两个字节functionGetBytes(str){varlen=str.varbytes=for(vari=0;i++){if(str.charCodeAt(i)255)bytes++;}}alert(GetBytes("你好,as"));9,编写一个方法去掉一个数组的重复元素vararr=[1,1,2,3,3,2,1];Array.prototype.unique=function(){varret=[];varo={};varlen=this.for(vari=0;i++){varv=this[i];if(!o[v]){o[v]=1;ret.push(v);}}};alert(arr.unique());10,写出3个使用this的典型应用(1)在html元素事件属性中使用,如inputtype=”button”onclick=”showInfo(this);”value=”点击一下”/(2)构造函数functionAnimal(name,color){this.name=this.color=}(3)inputtype="button"id="text"value="点击一下"/scripttype="text/javascript"varbtn=document.getElementById("text");btn.onclick=function(){alert(this.value);//此处的this是按钮元素}/script(4)CSSexpression表达式中使用this关键字tablewidth="100px"height="100px"&&&&41&&&&&&&&trtddivstyle="width:expression(this.parentNode.width);"divelement/div/td/tr/table12,如何显示/隐藏一个DOM元素?el.style.display="";el.style.display="none";el是要操作的DOM元素13,JavaScript中如何检测一个变量是一个String类型?请写出函数实现String类型有两种生成方式:(1)Varstr=“helloworld”;(2)Varstr2=newString(“helloworld”);functionIsString(str){return(typeofstr=="string"||str.constructor==String);}varstr="";alert(IsString(1));alert(IsString(str));alert(IsString(newString(str)));14,网页中实现一个计算当年还剩多少时间的倒数计时程序,要求网页上实时动态显示“××年还剩××天××时××分××秒”!DOCTYPEHTMLPUBLIC"-//W3C//DTDHTML4.01Transitional//EN""http://www.w3.org/TR/html4/loose.dtd"htmlheadmetahttp-equiv="Content-Type"content="text/charset=UTF-8"title倒计时/title/headbodyinputtype="text"value=""id="input"size="1000"/scripttype="text/javascript"functioncounter(){vardate=newDate();varyear=date.getFullYear();vardate2=newDate(year,12,31,23,59,59);vartime=(date2-date)/1000;varday=Math.floor(time/(24*60*60))varhour=Math.floor(time%(24*60*60)/(60*60))varminute=Math.floor(time%(24*60*60)%(60*60)/60);varsecond=Math.floor(time%(24*60*60)%(60*60)%60);varstr=year+"年还剩"+day+"天"+hour+"时"+minute+"分"+second+"秒";document.getElementById("input").value=}&&&&42&&&&&&&&window.setInterval("counter()",1000);/script/body/html15,补充代码,鼠标单击Button1后将Button1移动到Button2的后面divinputtype=”button”id=”button1〃value=”1〃onclick=”?”inputtype=”button”id=”button2〃value=”2〃/”/divdivinputtype="button"id="button1"value="1"onclick="moveBtn(this);"inputtype="button"id="button2"value="2"//divscripttype="text/javascript"functionmoveBtn(obj){varclone=obj.cloneNode(true);varparent=obj.parentNparent.appendChild(clone);parent.removeChild(obj);}/script16,JavaScript有哪几种数据类型简单:Number,Boolean,String,Null,Undefined复合:Object,Array,Function17,下面css标签在JavaScript中调用应如何拼写,border-left-color,-moz-viewportborderLeftColormozViewport18,JavaScript中如何对一个对象进行深度clonefunctioncloneObject(o){if(!o||'object'!==typeofo){}varc='function'===typeofo.pop?[]:{};varp,v;for(pino){if(o.hasOwnProperty(p)){v=o[p];if(v'object'===typeofv){c[p]=Ext.ux.clone(v);}else{c[p]=v;}}}};&&&&43&&&&&&&&19,如何控制alert中的换行\nalert(“p\np”);20,请实现,鼠标点击页面中的任意标签,alert该标签的名称.(注意兼容性)!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"htmlxmlns="http://www.w3.org/1999/xhtml"headmetahttp-equiv="Content-Type"content="text/charset=gb2312"/title鼠标点击页面中的任意标签,alert该标签的名称/titlestylediv{background:#0000FF;width:100height:100}span{background:#00FF00;width:100height:100}p{background:#FF0000;width:100height:100}/stylescripttype="text/javascript"document.onclick=function(evt){vare=window.event||vartag=e["target"]||e["srcElement"];alert(tag.tagName);};/script/headbodydivid="div"spanSPAN/spanDIV/divspanSPAN/spanpP/p/body/html21,请编写一个JavaScript函数parseQueryString,它的用途是把URL参数解析为一个对象,如:varurl=“http://witmax.cn/index.php?key0=0key1=1key2=2〃;functionparseQueryString(url){varparams={};vararr=url.split("?");if(arr.length=1)arr=arr[1].split("");for(vari=0,l=arr.i++){vara=arr[i].split("=");params[a[0]]=a[1];}}&&&&44&&&&&&&&varurl="http://witmax.cn/index.php?key0=0key1=1key2=2";varps=parseQueryString(url);alert(ps["key1"]);22,ajax是什么?ajax的交互模型?同步和异步的区别?如何解决跨域问题?Ajax是多种技术组合起来的一种浏览器和服务器交互技术,基本思想是允许一个互联网浏览器向一个远程页面/服务做异步的http调用,并且用收到的数据来更新一个当前web页面而不必刷新整个页面。该技术能够改进客户端的体验。包含的技术:XHTML:对应W3C的XHTML规范,目前是XHTML1.0。CSS:对应W3C的CSS规范,目前是CSS2.0DOM:这里的DOM主要是指HTMLDOM,XMLDOM包括在下面的XML中JavaScript:对应于ECMA的ECMAScript规范XML:对应W3C的XMLDOM、XSLT、XPath等等规范XMLHttpRequest:对应WhatWG的WebApplications1.0规范(http://whatwg.org/specs/web-apps/current-work/)AJAX交互模型同步:脚本会停留并等待服务器发送回复然后再继续异步:脚本允许页面继续其进程并处理可能的回复跨域问题简单的理解就是因为JS同源策略的限制,a.com域名下的JS无法操作b.com或c.a.com下的对象,具体场景如下:PS:(1)如果是端口或者协议造成的跨域问题前端是无能为力的(2)在跨域问题上,域仅仅通过URL的首部来识别而不会尝试判断相同的IP地址对应的域或者两个域是否对应一个IP前端对于跨域的解决办法:(1)document.domain+iframe(2)动态创建script标签23,什么是闭包?下面这个ul,如何点击每一列的时候alert其index?ulid=”test”li这是第一条/lili这是第二条/lili这是第三条/li/ul内部函数被定义它的函数的外部区域调用的时候就产生了闭包。(functionA(){varindex=0;varul=document.getElementById("test");varobj={};for(vari=0,l=ul.childNodes.i++){if(ul.childNodes[i].nodeName.toLowerCase()=="li"){varli=ul.childNodes[i];li.onclick=function(){index++;alert(index);&&&&45&&&&&&&&}}}})();24,请给出异步加载js方案,不少于两种默认情况javascript是同步加载的,也就是javascript的加载时阻塞的,后面的元素要等待javascript加载完毕后才能进行再加载,对于一些意义不是很大的javascript,如果放在页头会导致加载很慢的话,是会严重影响用户体验的。异步加载方式:(1)defer,只支持IE(2)async:(3)创建script,插入到DOM中,加载完毕后callBack,见代码:functionloadScript(url,callback){varscript=document.createElement("script")script.type="text/javascript";if(script.readyState){//IEscript.onreadystatechange=function(){if(script.readyState=="loaded"||script.readyState=="complete"){script.onreadystatechange=callback();}};}else{//Others:Firefox,Safari,Chrome,andOperascript.onload=function(){callback();};}script.src=document.body.appendChild(script);}25,请设计一套方案,用于确保页面中JS加载完全。varn=document.createElement("script");n.type="text/javascript";//以上省略部分代码//ie支持script的readystatechange属性(IEsupportthereadystatechangeeventforscriptandcssnodes)if(ua.ie){n.onreadystatechange=function(){varrs=this.readySif('loaded'===rs||'complete'===rs){n.onreadystatechange=f(id,url);//回调函数}};&&&&46&&&&&&&&//省略部分代码//safari3.xsupportstheloadeventforscriptnodes(DOM2)n.addEventListener('load',function(){f(id,url);});//firefoxandoperasupportonload(butnotdom2inff)handlersfor//scriptnodes.opera,butnoff,supporttheonloadeventforlink//nodes.}else{n.onload=function(){f(id,url);};}26,js中如何定义class,如何扩展prototype?Ele.className=“***”;//***在css中定义,形式如下:.***{?}A.prototype.B=C;A是某个构造函数的名字B是这个构造函数的属性C是想要定义的属性的值27,如何添加html元素的事件,有几种方法.(1)为HTML元素的事件属性赋值(2)在JS中使用ele.on***=function(){?}(3)使用DOM2的添加事件的方法addEventListener或attachEvent28,documen.write和innerHTML的区别document.write只能重绘整个页面innerHTML可以重绘页面的一部分29,多浏览器检测通过什么?(1)navigator.userAgent(2)不同浏览器的特性,如addEventListener30,js的基础对象有那些,window和document的常用的方法和属性列出来String,Number,BooleanWindow:方法:setInterval,setTimeout,clearInterval,clearTimeout,alert,confirm,open属性:name,parent,screenLeft,screenTop,self,top,statusDocument方法:createElement,execCommand,getElementById,getElementsByName,getElementByTagName,write,writeln属性:cookie,doctype,domain,documentElement,readyState,URL,31,前端开发的优化问题(1)减少http请求次数:cssspirit,datauri(2)JS,CSS源码压缩(3)前端模板JS+数据,减少由于HTML标签导致的带宽浪费,前端用变量保存AJAX请求结果,每次操作本地变量,不用请求,减少请求次数(4)用innerHTML代替DOM操作,减少DOM操作次数,优化javascript性能(5)用setTimeout来避免页面失去响应&&&&47&&&&&&&&(6)用hash-table来优化查找(7)当需要设置的样式很多时设置className而不是直接操作style(8)少用全局变量(9)缓存DOM节点查找的结果(10)避免使用CSSExpression(11)图片预载(12)避免在页面的主体布局中使用table,table要等其中的内容完全下载之后才会显示出来,显示比div+css布局慢32,如何控制网页在网络传输过程中的数据量启用GZIP压缩保持良好的编程习惯,避免重复的CSS,JavaScript代码,多余的HTML标签和属性33,Flash、Ajax各自的优缺点,在使用中如何取舍?Ajax的优势(1)可搜索型(2)开放性(3)费用(4)易用性(5)易于开发Flash的优势(1)多媒体处理(2)兼容性(3)矢量图形比SVG,Canvas优势大很多(4)客户端资源调度,比如麦克风,摄像头4用脚本写去除字符串的前后空格String.prototype.trim=function(mode){//前后去空格if(mode==’left’),return((this.charAt(0)==”“this.length0)?this.slice(1).trim(’left’):this);}elseif(mode==’right’),return((this.charAt(this.length-1)==”“this.length0)?this.slice(0,this.length-1).trim(’right’):this);}else{returnthis.trim(’left’).trim(’right’);}};5算出字符串中出现次数最多的字符是什么,出现了多少次scripttype=”text/javascript”//![CDATA[varstr="adadfdfseffserfefsefseeffffftsdg";//命名一个变量放置给出的字符串varmaxLength=0;//命名一个变量放置字母出现的最高次数并初始化为0varresult='';//命名一个变量放置结果输入while(str!=''){//循环迭代开始,并判断字符串是否为空&&&&48&&&&&&&&oldStr=//将原始的字符串变量赋值给新变量getStr=str.substr(0,1);//用字符串的substr的方法得到第一个字符(首字母)eval("str=str.replace(/"+getStr+"/g,'')");//详细如补充if(oldStr.length-str.lengthmaxLength){//判断原始的字符串的长度减去替代后字符串长度是否大于之前出现的最大的字符串长度maxLength=oldStr.length-str.//两字符串长度相减得到最大的字符串长度result=getStr+"="+maxLength//返回最大的字符串结果(字母、出现次数)}}alert(result)//弹出结果//]]/script6写出3中使用this的典型应用在HTML元素事件属性中inline方式使用this关键字:7.最后一个问题是,如何制作一个combo选项,就是可以输入可以下拉菜单选择。这个网上有很多成品,主要是通过绝对定位和相对定位结合的方式,改造原有的select标签和input标签的方法。附上javascript正则表达式的基本知识:g:全局匹配i:忽略大小写^匹配一个输入或一行的开头,/^a/匹配”anA”,而不匹配”Ana”$匹配一个输入或一行的结尾,/a$/匹配”Ana”,而不匹配”anA”*匹配前面元字符0次或多次,/ba*/将匹配b,ba,baa,baaa+匹配前面元字符1次或多次,/ba*/将匹配ba,baa,baaa?匹配前面元字符0次或1次,/ba*/将匹配b,ba(x)匹配x保存x在名为$1?$9的变量中x|y匹配x或y{n}精确匹配n次{n,}匹配n次以上{n,m}匹配n-m次[xyz]字符集(characterset),匹配这个集合中的任一一个字符(或元字符)[^xyz]不匹配这个集合中的任何一个字符[b]匹配一个退格符b匹配一个单词的边界B匹配一个单词的非边界cX这儿,X是一个控制符,/cM/匹配Ctrl-Md匹配一个字数字符,/d/=/[0-9]/D匹配一个非字数字符,/D/=/[^0-9]/n匹配一个换行符r匹配一个回车符s匹配一个空白字符,包括n,r,f,t,v等S匹配一个非空白字符,等于/[^nfrtv]/t匹配一个制表符&&&&49&&&&&&&&v匹配一个重直制表符w匹配一个可以组成单词的字符(alphanumeric,这是我的意译,含数字),包括下划线,如[w]匹配”$5.98〃中的5,等于[a-zA-Z0-9]W匹配一个不可以组成单词的字符,如[W]匹配”$5.98〃中的$,等于[^a-zA-Z0-9举例:验证emailvarmyReg=/^[_a-z0-9]+@([_a-z0-9]+.)+[a-z0-9]{2,3}$/;if(myReg.test(strEmail))Date对象属性FF:Firefox,IE:InternetExplorer属性描述FFIEconstructor返回对创建此对象的Date函数的引用。14}

我要回帖

更多关于 img标签alt属性 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信