首页 > 前端开发 > 正文

web前端开发面临的挑战主要是有哪些?

2023-10-22 07:05:50 | 我爱编程网

今天,我爱编程网小编为关注前端开发的同学们准备了web前端开发面临的挑战主要是有哪些?,下面一起来看一下吧。

本文目录一览:

web前端开发面临的挑战主要是有哪些?

web前端开发面临的挑战主要是有哪些?

web前端面临的挑战:

1.兼容性:市场上浏览器种类非常多,IE、Firefox、Chrome、Opera、还有众多的IE加壳浏览器,类似搜狗、傲游、360,再加上这些浏览器的移动终端版本。需要有Web标准,前端的知识大部分通用于各个浏览器,但还是会有历史遗留问题,不同版本的浏览器有不同的问题。
2.交互复杂度:和目前UI交互的要求比,浏览器引擎给我们的接口太低级了,稍复杂一点的UI效果,都要前端自己利用CSS和DOM去组合创造,前端的效果是通过CSS、DOM、JS三者配合起来呈现出来的,脱了任何一个技术都寸步难行,时刻要同时考虑多个方向的知识点。
3.代码可维护性:复杂度的提升直接影响代码的维护性。JS/CSS/HTML代码生命周期越来越长,也就越来越需要从代码质量、架构和工具上保证他们的可维护性。
4.技术更新快:前端技术更新速度十分快,html5,css3,nodejs,commonjs,按需加载等都是近几年出来的,我们必须与时俱进,不断加强技术水平,不断学习,不然就会被淘汰。
5.开发者思路:真正的前端开发挑战,还在于开发者的思路。

想要了解更多有关web前端的相关信息, 推荐咨询千锋教育 。千锋教育成立教研学科中心,推出贴近企业需求的线下技能培训课程。采用全程面授高品质、高体验培养模式,学科大纲紧跟企业需求,拥有国内一体化教学管理及学员服务,在职业教育发展道路上不断探索前行。

web前端开发面临的挑战主要是有哪些?

Tomcat上开发Web应用如何保证兼容性


最近,协助伙伴将Tomcat上开发的应用向Apusic移植时发现了一个兼容性问题。
应用中代码为:HashMap params = (HashMap) request.getParameterMap();
而getParameterMap()在JCP规范中的定义为:public java.util.Map getParameterMap()
Returns a java.util.Map of the parameters of this request. Request parameters are extra information sent with the request. For HTTP servlets, parameters are contained in the query string or posted form data.请求的参数将返回一个java.util.Map.请求参数是请求发送的特别信息。对于HTTP servlets来说,参数包含在查询字符串或者发出的表单数据中。
Returns: an immutable java.util.Map containing parameter names as keys and parameter values as map values. The keys in the parameter map are of type String. The values in the parameter map are of type String array.一个不可更改的java.util.Map包含参数名称(关键字)和参数值(映射值)。参数映射中的关键字是String类型。参数映射中的值是String数组类型。
可见规范中定义的返回值只是Map类型,而没有强制为HashMap. Apusic在实现的时候也是Map作为返回值,而Tomcat返回时(参考org.apache.catalina.connector.Request.java)就是一个扩展自HashMap的ParameterMap类,因此开发时如何作为Map来用也不会出现问题,但是如果强制转换成HashMap就可能会与其他应用服务器产品无法正确兼容。
Tomcat是一款非常不错的开源Web服务器,许多公司在软件开发时都使用Tomcat作为Web容器,并且Tomcat也较好的对Servlet和JSP规范进行了支持,因此许多在Tomcat上开发的应用都可以向其他商业应用服务器上进行移植。
但是,Tomcat因为未去通过规范测试,因此可能会存在没有完全参考规范实现的部分,因此在开发中建议开发人员去上去下载一个规范来进行参考,开发过程中尽可能按照规范给定的参数和返回值来使用系统的核心功能,从而避免在移植中出现不必要的问题。
附注:出现问题也不可怕,总有许多方式可以解决,就如上文出现的Map与HashMap的问题。其实网上有许多Map向HashMap转换的代码,可以增加个过渡参数将得到的Map进行一次转换就可以不修改其他业务代码了。

web前端开发面临的挑战主要是有哪些?

Web前端中常见的浏览器兼容问题有哪些

使用Trident内核的浏览器:IE、Maxthon、TT; 使用Gecko内核的浏览器:Netcape6及以上版本、FireFox; 使用Presto内核的浏览器:Opera7及以上版本; 使用Webkit内核的浏览器:Safari、Chrome。
而我现在所说的兼容性问题,主要是说IE与几个主流浏览器如firefox,google等。而对IE浏览器来说,IE7又是个跨度,因为之前的版本更新甚慢,bug甚多。从IE8开始,IE浏览器渐渐遵循标准,到IE9后由于大家都一致认为标准很重要,可以说在兼容性上比较好了,但是在中国来说,由于xp的占有率问题,使用IE7以下的用户仍然很多,所以我们不得不考虑低版本浏览器的兼容。

对浏览器兼容问题,一般分,HTML,Javascript兼容,CSS兼容。 其中html相关问题比较容易处理,无非是高版本浏览器用了低版本浏览器无法识别的元素,导致其不能解析,所以平时注意一点就是。特别是HTML5增加了许多新标签,低版本浏览器有点影响时代进步啊

问题一:不同浏览器的标签默认的外补丁和内补丁不同

  • 问题症状:随便写几个标签,不加样式控制的情况下,各自的margin 和padding差异较大。

  • 碰到频率:100%

  • 解决方案:css里 *{margin:0;padding:0;}

  • 备注:这个是最常见的也是最易解决的一个浏览器兼容性问题,几乎所有的css文件开头都会用通配符*来设置各个标签的内外补丁是0。

  • 问题二:块属性标签float后,又有横行的margin情况下,在ie6显示margin比设置的大

  • 问题症状:常见症状是ie6中后面的一块被顶到下一行

  • 碰到频率:90%(稍微复杂点的页面都会碰到,float布局最常见的浏览器兼容问题)

  • 解决方案:在float的标签样式控制中加入 display:inline;将其转化为行内属性

  • 备注:我们最常用的就是div+css布局了,而div就是一个典型的块属性标签,横向布局的时候我们通常都是用div float实现的,横向的间距设置如果用margin实现,这就是一个必然会碰到的兼容性问题。

  • 问题三:设置较小高度标签(一般小于10px),在ie6,ie7,遨游中高度超出自己设置高度

  • 问题症状:ie6、7和遨游里这个标签的高度不受控制,超出自己设置的高度

  • 碰到频率:60%

  • 解决方案:给超出高度的标签设置overflow:hidden;或者设置行高line-height 小于你设置的高度。

  • 备注:这种情况一般出现在我们设置小圆角背景的标签里。出现这个问题的原因是ie8之前的浏览器都会给标签一个最小默认的行高的高度。即使你的标签是空的,这个标签的高度还是会达到默认的行高。

  • 问题四:行内属性标签,设置display:block后采用float布局,又有横行的margin的情况,ie6间距bug(类似第二种)

  • 问题症状:ie6里的间距比超过设置的间距

  • 碰到几率:20%

  • 解决方案:在display:block;后面加入display:inline;display:table;

  • 备注:行内属性标签,为了设置宽高,我们需要设置display:block;(除了input标签比较特殊)。在用float布局并有横向的margin后,在ie6下,他就具有了块属性float后的横向margin的bug。不过因为它本身就是行内属性标签,所以我们再加上display:inline的话,它的高宽就不可设了。这时候我们还需要在display:inline后面加入display:talbe。

  • 问题五:图片默认有间距

  • 问题症状:几个img标签放在一起的时候,有些浏览器会有默认的间距,加上问题一中提到的通配符也不起作用。

  • 碰到几率:20%

  • 解决方案:使用float属性为img布局

  • 备注:因为img标签是行内属性标签,所以只要不超出容器宽度,img标签都会排在一行里,但是部分浏览器的img标签之间会有个间距。去掉这个间距使用float是正道

  • 问题六:标签最低高度设置min-height不兼容

  • 问题症状:因为min-height本身就是一个不兼容的css属性,所以设置min-height时不能很好的被各个浏览器兼容

  • 碰到几率:5%

  • 解决方案:如果我们要设置一个标签的最小高度200px,需要进行的设置为:{min-height:200px; height:auto !important; height:200px; overflow:visible;}

  • 备注:在B/S系统前端开时,有很多情况下我们有这种需求。当内容小于一个值(如300px)时。容器的高度为300px;当内容高度大于这个值时,容器高度被撑高,而不是出现滚动条。这时候我们就会面临这个兼容性问题。

  • 问题七:透明度的兼容css设置

  • 方法是:每写一小段代码(布局中的一行或者一块)我们都要在不同的浏览器中看是否兼容,当然熟练到一定的程度就没这么麻烦了。建议经常会碰到兼容性问题的新手使用。很多兼容性问题都是因为浏览器对标签的默认属性解析不同造成的,只要我们稍加设置都能轻松地解决这些兼容问题。如果我们熟悉标签的默认属性的话,就能很好的理解为什么会出现兼容问题以及怎么去解决这些兼容问题。1

  • 技巧一:css hack

    使用hacker 我可以把浏览器分为3类:ie6 ;ie7和遨游;其他(ie8 chrome ff safari opera等)

  • ie6认识的hacker 是下划线_ 和星号 *

  • ie7 遨游认识的hacker是星号 * (包括上面问题6中的 !important也算是hack的一种。不过实用性较小。)

  • 比如这样一个css设置 height:300px;*height:200px;_height:100px;ie6浏览器在读到 height:300px的时候会认为高时300px;继续往下读,他也认识*heihgt, 所以当ie6读到*height:200px的时候会覆盖掉前一条的相冲突设置,认为高度是200px。继续往下读,ie6还认识_height,所以他又会覆盖掉200px高的设置,把高度设置为100px;

  • ie7和遨游也是一样的从高度300px的设置往下读。当它们读到*height200px的时候就停下了,因为它们不认识_height。所以它们会把高度解析为200px;

  • 剩下的浏览器只认识第一个height:300px;所以他们会把高度解析为300px。1234

  • 因为优先级相同且相冲突的属性设置后一个会覆盖掉前一个,所以书写的次序是很重要的。

  • /* CSS属性级Hack */ color:red; /* 所有浏览器可识别*/_color:red; /* 仅IE6 识别 */*color:red; /* IE6、IE7 识别 */+color:red; /* IE6、IE7 识别 */*+color:red; /* IE6、IE7 识别 */[color:red; /* IE6、IE7 识别 */ color:red\9; /* IE6、IE7、IE8、IE9 识别 */color:red\0; /* IE8、IE9 识别*/color:red\9\0; /* 仅IE9识别 */color:red \0; /* 仅IE9识别 */color:red!important; /* IE6 不识别!important 有危险*//* CSS选择符级Hack */ *html #demo { color:red;} /* 仅IE6 识别 */*+html #demo { color:red;} /* 仅IE7 识别 */body:nth-of-type(1) #demo { color:red;} /* IE9+、FF3.5+、Chrome、Safari、Opera 可以识别

  • */ head:first-child+body #demo { color:red; } /* IE7+、FF、Chrome、Safari、Opera 可以识别 */:root #demo { color:red\9; } : /* 仅IE9识别 */123456789101112131415161718192021222324252627282930313233

  • 越少的浮动,就会越少的代码,会有更灵活的页面,会有扩展性更强的页面。这不多说,归结为到一定水平了,浮动会用的较少。另外,您也会避免使用浮动+margin的用法。所以,越后来越不易遇到这种bug。

    技巧二:padding,marign,height,width

    注意是技巧,不是方法: 写好标准头 -transitional.dtd”> ”> 尽量用padding,慎用margin,height尽量补上100%,父级height有定值子级height不用100%,子级全为浮动时底部补个空clear:both的div宽尽量用margin,慎用padding,width算准实际要的减去padding

    技巧三:显示类(display:block,inline)

  • display:block,inline两个元素


  • display:block; //可以为内嵌元素模拟为块元素display:inline; //实现同一行排列的的效果display:table; //for FF,模拟table的效果1234567

  • display:block块元素,元素的特点是: 总是在新行上开始;高度,行高以及顶和底边距都可控制;宽度缺省是它的容器的100%,除非设定一个宽度 我爱编程网

    display:inline就是将元素显示为行内元素,元素的特点是:和其他元素都在一行上;高,行高及顶和底边距不可改变;宽度就是它的文字或图片的宽度,不可改变。span,a,label,input,img,strong和em是 inline 元素的例子

    技巧四:怎样使一个div层居中于浏览器中?

    1)

  • <style type="text/css"><!-- div {position:absolute;top:50%;left:50%;margin:-100px 0 0 -100px;width:200px;height:200px;border:1px solid red; } --></style>12345678910111213141516171819

  • 2)div里的内容,IE默认为居中,而FF默认为左对齐,可以尝试增加代码margin: 0 auto;

    技巧五:float的div闭合;清除浮动;自适应高度

    ① 例如:<div id="floatA"><div id="floatB"><div id="NOTfloatC">

  • 这里的NOTfloatC并不希望继续平移,而是希望往下排。(其中floatA、floatB的属性已经设置为float:left;)

  • 这段代码在IE中毫无问题,问题出在FF。原因是NOTfloatC并非float标签,必须将float标签闭合。在<divclass="floatB"><div class="NOTfloatC">之间加上<div class="clear">这个div一定要注意位置,而且必须与两个具有float属性的div同级,之间不能存在嵌套关系,否则会产生异常。并且将clear这种样式定义为为如下即可:.clear{clear:both;}

  • ②作为外部 wrapper 的 div 不要定死高度,为了让高度能自适应,要在wrapper里面加上overflow:hidden; 当包含float的box的时候,高度自适应在IE下无效,这时候应该触发IE的layout私有属性(万恶的IE啊!)用zoom:1;可以做到,这样就达到了兼容。
    例如某一个wrapper如下定义:

  • .colwrapper{overflow:hidden; zoom:1; margin:5px auto;}1

  • ③对于排版,我们用得最多的css描述可能就是float:left.有的时候我们需要在n栏的float div后面做一个统一的背景,譬如:

  • <div id=”page”>


  • <div id=”left”></div>

  • <div id=”center”></div>

  • <div id=”right”></div>


  • </div>1234567

  • 比如我们要将page的背景设置成蓝色,以达到所有三栏的背景颜色是蓝色的目的,但是我们会发现随着left centerright的向下拉长,而page居然保存高度不变,问题来了,原因在于page不是float属性,而我们的page由于要居中,不能设置成float,所以我们应该这样解决:

  • <div id=”page”>


  • <div id=”bg” style=”float:left;width:100%”>


  • <div id=”left”></div>

  • <div id=”center”></div>

  • <div id=”right”></div>


  • </div>


  • </div>1234567891011

  • 再嵌入一个float left而宽度是100%的DIV解决之。

    ④万能float 闭合(非常重要!)

    关于 clear float 的原理可参见 [How To ClearFloats Without Structural Markup],将以下代码加入Global CSS 中,给需要闭合的div加上class=”clearfix”即可,屡试不爽。

  • /* Clear Fix */ .clearfix:after { content:"."; display:block; height:0; clear:both;visibility:hidden; } .clearfix { display:inline-block; } /* Hide from IE Mac */ .clearfix {display:block;} /* End hide from IE Mac */ /* end of clearfix */1234567

  • 或者这样设置:.hackbox{display:table; //将对象作为块元素级的表格显示}

    技巧六:div嵌套时 y轴上 padding和 marign的问题

  • FF里 y 轴上 子div 到 父div 的距离为 父padding + 子marign

  • IE里 y 轴上 子div 到 父div 的距离为 父padding 和 子marign 里大的一个

  • FF里 y 轴上 父padding=0 且 border=0 时,子div 到 父div 的距离为0,子marign 作用到 父div 外面

以上就是我爱编程网小编为大家带来的web前端开发面临的挑战主要是有哪些?,希望对大家有帮助,了解更多相关资讯请关注我爱编程网。
与“web前端开发面临的挑战主要是有哪些?”相关推荐
web前端开发挑战 web前端开发是什么,所要面临的挑战有哪些?
web前端开发挑战 web前端开发是什么,所要面临的挑战有哪些?

web前端就业前景如何?前端开发的就业现状及前景如下:1、web前端技术岗位需求量大据各大招聘平台数据统计,企业对于web前端技术岗位的需求是非常大的,未来五年我国信息化人才总需求高达1500万-2000万人。其中“网络工程”“UI设计”“Web前端”等人才的缺口最为突出,所以Web前端的市场需求很大。2、web前端的薪资待遇非常可观web前端这个行业的薪资待遇是

2023-09-05 01:18:58
web前端开发哪些难 web前端开发面临的挑战主要是有哪些?
web前端开发哪些难 web前端开发面临的挑战主要是有哪些?

web前端开发难不难学?不难,但是也不简单,需要学html,css,js还有数据库,一些框架。我自学过一段时间,没学会,建议报班吧,自学感觉学不会。没啥太大的难度,好好跟着上课,从0开始学,没啥的问题,优就业不错,可以去瞧瞧。Web前端开发,是近五年才真正开始受到重视的一个新兴职业。Web前端开发技术是一个先易后难的过程,主要包括三个要素:HTML、CSS和Java,这就要求前

2023-08-30 18:13:50
web前端开发例子 web前端开发面临的挑战主要是有哪些?
web前端开发例子 web前端开发面临的挑战主要是有哪些?

web前端开发面临的挑战主要是有哪些?web前端面临的挑战:1.兼容性:市场上浏览器种类非常多,IE、Firefox、Chrome、Opera、还有众多的IE加壳浏览器,类似搜狗、傲游、360,再加上这些浏览器的移动终端版本。需要有Web标准,前端的知识大部分通用于各个浏览器,但还是会有历史遗留问题,不同版本的浏览器有不同的问题。2.交互复杂度:和目前UI交互的要求比,浏览器引擎给

2023-08-27 23:29:58
web前端开发有哪些比赛 web前端开发面临的挑战主要是有哪些
web前端开发有哪些比赛 web前端开发面临的挑战主要是有哪些

web前端开发面临的挑战主要是有哪些web前端面临的挑战:1.兼容性:市场上浏览器种类非常多,IE、Firefox、Chrome、Opera、还有众多的IE加壳浏览器,类似搜狗、傲游、360,再加上这些浏览器的移动终端版本。需要有Web标准,前端的知识大部分通用于各个浏览器,但还是会有历史遗留问题,不同版本的浏览器有不同的问题。2.交互复杂度:和目前UI交互的要求比,浏览器引擎给我

2023-09-23 17:40:53
web前端开发遇到的挑战 web前端开发是什么,所要面临的挑战有哪些?
web前端开发遇到的挑战 web前端开发是什么,所要面临的挑战有哪些?

web前端就业前景如何?前端开发的就业现状及前景如下:1、web前端技术岗位需求量大据各大招聘平台数据统计,企业对于web前端技术岗位的需求是非常大的,未来五年我国信息化人才总需求高达1500万-2000万人。其中“网络工程”“UI设计”“Web前端”等人才的缺口最为突出,所以Web前端的市场需求很大。2、web前端的薪资待遇非常可观web前端这个行业的薪资待遇是

2023-09-28 04:22:51
web前端开发是什么,所要面临的挑战有哪些?
web前端开发是什么,所要面临的挑战有哪些?

web前端开发是什么,所要面临的挑战有哪些?Web前端开发大致上是,创建出Web网页以供用户浏览使用等。主要通过HTML、CSS、JavaScript等技术来实现交互。所面临的挑战主要有几点:一、Web的载体的多样性。以浏览器为例,分别有IE,Chrome,火狐等。虽然有ECMA委员会进行标准化,但不同浏览器对HTML、CSS、JS等支持程度还是存在差异。所以需要进

2023-10-20 13:54:04
web前端开发jsp web前端开发是什么,所要面临的挑战有哪些?
web前端开发jsp web前端开发是什么,所要面临的挑战有哪些?

web前端开发是什么,所要面临的挑战有哪些?Web前端开发大致上是,创建出Web网页以供用户浏览使用等。主要通过HTML、CSS、JavaScript等技术来实现交互。所面临的挑战主要有几点:一、Web的载体的多样性。以浏览器为例,分别有IE,Chrome,火狐等。虽然有ECMA委员会进行标准化,但不同浏览器对HTML、CSS、JS等支持程度还是存在差异。所以需要进

2023-08-29 09:11:14
web前端开发react web前端开发是什么,所要面临的挑战有哪些?
web前端开发react web前端开发是什么,所要面临的挑战有哪些?

web前端开发是什么,所要面临的挑战有哪些?Web前端开发大致上是,创建出Web网页以供用户浏览使用等。主要通过HTML、CSS、JavaScript等技术来实现交互。所面临的挑战主要有几点:一、Web的载体的多样性。以浏览器为例,分别有IE,Chrome,火狐等。虽然有ECMA委员会进行标准化,但不同浏览器对HTML、CSS、JS等支持程度还是存在差异。所以需要进

2023-09-08 21:11:48