2020秋招前端面经知识点汇总(一) html,css部分

作者:北风菌

链接:https://juejin.im/post/6876623829574090760

来源:掘金

好久没有更新帖子了,最近一直在复习准备秋招,最近终于拿到了第一份意向书,终于有时间来整理一下自己最近的复习内容,以下知识点都是楼主在面试中被问到的问题,我做了几大块的分类,各位需要的小伙伴可以收藏一下。因为还在继续面试,所以还会不定时更新,因为掘金这边文章有字数限制,所以这边放出了HTML部分,CSS部分,JS部分的知识点,Vue,git,webpack,计网相关的知识点放在下一篇文章中juejin.im/post/687707… 。

HTML部分:

HTML标签的分类:

HTML文档标签

:定义文档类型。

: 定义HTML文档。

:定义文档的头部。:定义元素可提供的有关页面的元信息,比如针对搜索引擎和更新频度的描述和关键字。meta标签共有两个属性, http-equiv属性:相当于http头文件的作用,向浏览器传回一些有用的信息,使用content规定属性的内容比如

2020秋招前端面经知识点汇总(一) html,css部分_第1张图片

name属性:主要用来描述网页,content中的内容主要是便于搜索引擎机器人查找信息和分类信息用的。


:定义页面上的所有链接规定默认地址或默认目标。:定义文档标题。<link>:定义文档与外部资源的关系。<style>:定义HTML文档样式信息。</p> <p><body>:定义文档的主体。(脚本在非必需情况时在的最后)<script>:定义客户端脚本,比如javascript。<noscript>:定义脚本未被执行时的替代内容。(如文本)</p> <p>按闭合特征分类:</p> <p>闭合标签是指由开始标签和结束标签组成的一对标签,这种标签允许嵌套和承载内容,例如<html></html>、<p></p>等。</p> <p>空标签是指没有内容的标签,在开始标签中自动闭合。常见的空标签有:<br>、<hr>、 <img>、 <input>、 <link> <meta>。</p> <p>按是否换行特征分类:</p> <p>块级元素:块级元素是值本身属性为display:block的元素。</p> <p>内联元素:内联元素是指本身属性为display:inline的元素,其宽度随元素的内容而变化。</p> <p> 块级元素的特点:</p> <p>每个块级元素独占一行,从上到下排布。</p> <p>块级元素可以直接控制宽度高度等盒子模型相关的css属性。</p> <p>不设置宽度的情况下,块级元素的宽度是其父级元素内容的宽度。</p> <p>不设置高度的情况下,块级元素的高度是他本身内容的高度。</p> <p> 常用块级元素:</p> <p><br></p> <div class="image-package"> <div class="image-container" style="max-width: 440px; max-height: 262px;"> <div class="image-view"> <a href="http://img.e-com-net.com/image/info10/1ff88763b4bf4c048012deb85a91b944.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info10/1ff88763b4bf4c048012deb85a91b944.jpg" width="440" height="262" alt="2020秋招前端面经知识点汇总(一) html,css部分_第2张图片" style="border:1px solid black;"></a> </div> </div> <div class="image-caption"></div> </div> <p> 内联元素的特点:</p> <p>内联元素会和其他元素从左到右显示在一行中。</p> <p>内联元素不能直接控制宽度高度以及盒子模型相关的css属性,可以设置内外边距的水平方向的值。也就是说,对于内联元素的margin和padding,只有margin-left/margin-right和padding-left/padding-right是有效的,竖直方向的margin和pading无效果。</p> <p>内联元素的宽高是由其内容本身的大小决定的。</p> <p>内联元素只能容纳文本或者其他内联元素,不允许在内联元素中嵌套块级元素。</p> <p> 常见的内联元素:</p> <p><br></p> <div class="image-package"> <div class="image-container" style="max-width: 428px; max-height: 213px;"> <div class="image-view"> <a href="http://img.e-com-net.com/image/info10/dd980052e12e47068eeaafdd9f923109.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info10/dd980052e12e47068eeaafdd9f923109.jpg" width="428" height="213" alt="2020秋招前端面经知识点汇总(一) html,css部分_第3张图片" style="border:1px solid black;"></a> </div> </div> <div class="image-caption"></div> </div> <p> H5新特性(常用):</p> <p><br></p> <div class="image-package"> <div class="image-container" style="max-width: 433px; max-height: 267px;"> <div class="image-view"> <a href="http://img.e-com-net.com/image/info10/1cc08035be2f4fa0882dffca4271e2b2.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info10/1cc08035be2f4fa0882dffca4271e2b2.jpg" width="433" height="267" alt="2020秋招前端面经知识点汇总(一) html,css部分_第4张图片" style="border:1px solid black;"></a> </div> </div> <div class="image-caption"></div> </div> <p> HTML5新增元素:</p> <p> 1)标签增删 8个语义元素 header section footer aside nav main article figure内容元素mark高亮 progress进度</p> <p>新的表单控件calander date time email url search新的input类型 color date datetime datetime-local email移除过时标签big font frame frameset2)canvas绘图,支持内联SVG。支持MathML</p> <p>3)多媒体audio video source embed track4)本地离线存储,把需要离线存储在本地的文件列在一个manifest配置文件</p> <p>5)web存储,localStorage、SessionStorage cookie sessionStorage localStorage区别:</p> <p> Cookie属性详解Name字段:为一个cookie的名称Value字段:为一个cookie的值Domain字段:为可以访问此cookie的域名,二级域名可以获取顶级域名中的cookie,同二级域名之间不可相互获取,顶级域名不可获取二级域名的cookiePath字段:为可以访问此cookie的页面路径,只有此路径下的页面可以读取此cookieExpires/Max-Age字段:为此cookie的超时时间,若设置为一个时间,则当达到此时间之后,此cookie失效,不设置的话默认值为Session,即浏览器关闭后才会失效。Size字段:表示此cookie的大小http字段:表示此cookie的httponly属性,若此属性设置为true,则只有在http请求头中会带有此cookie的信息,而不能通过document.cookie来访问。Secure字段:表示设置是否只能通过https来传递此条cookie。</p> <p> Cookie与webstorage:</p> <p>cookie数据始终在同源的http请求中携带(即使不需要),即cookie在浏览器和服务器间来回传递。</p> <p>cookie数据还有路径(path)的概念,可以限制。cookie只属于某个路径下存储大小限制也不同,cookie数据不能超过4K,同时因为每次http请求都会携带cookie,所以cookie只适合保存很小的数据,如回话标识。</p> <p>webStorage虽然也有存储大小的限制,但是比cookie大得多,可以达到5M或更大</p> <p>sessionStorage与localStorage:</p> <p>数据的有效期不同:</p> <p>sessionStorage:仅在当前的浏览器窗口关闭有效;</p> <p>localStorage:始终有效,窗口或浏览器关闭也一直保存,因此用作持久数据;cookie:只在设置的cookie过期时间之前一直有效,即使窗口和浏览器关闭。</p> <p>作用域不同:</p> <p>sessionStorage:不在不同的浏览器窗口中共享,即使是同一个页面;localStorage:在所有同源窗口都是共享的;</p> <p>cookie:也是在所有同源窗口中共享的。</p> <p> HTTP状态码:</p> <p> 1xx(临时响应):表示临时响应并需要请求者继续执行操作的状态码。</p> <p>100(继续)请求者应当继续提出请求。服务器返回此代码表示已收到请求的第一部分,正在等待其余部分。</p> <p>101(切换协议)请求者已要求服务器切换协议,服务器已确认并准备切换。</p> <p> 2xx (成功):表示成功处理了请求的状态码。</p> <p>200(成功)服务器已成功处理了请求。通常,这表示服务器提供了请求的网页。如果是对您的 robots.txt 文件显示此状态码,则表示 Googlebot 已成功检索到该文件。</p> <p>201(已创建)请求成功并且服务器创建了新的资源。</p> <p>202(已接受)服务器已接受请求,但尚未处理。</p> <p>203(非授权信息)服务器已成功处理了请求,但返回的信息可能来自另一来源。</p> <p>204(无内容)服务器成功处理了请求,但没有返回任何内容。</p> <p>205(重置内容)服务器成功处理了请求,但没有返回任何内容。与 204 响应不同,此响应要求请求者重置文档视图(例如,清除表单内容以输入新内容)。</p> <p>206(部分内容)服务器成功处理了部分 GET 请求。</p> <p> 3xx (重定向):要完成请求,需要进一步操作。通常,这些状态码用来重定向。</p> <p>300(多种选择)针对请求,服务器可执行多种操作。服务器可根据请求者 (user agent) 选择一项操作,或提供操作列表供请求者选择。</p> <p>301(永久移动)请求的网页已永久移动到新位置。服务器返回此响应(对 GET 或 HEAD 请求的响应)时,会自动将请求者转到新位置。您应使用此代码告诉 Googlebot 某个网页或网站已永久移动到新位置。</p> <p>302(临时移动)服务器目前从不同位置的网页响应请求,但请求者应继续使用原有位置来响应以后的请求。此代码与响应 GET 和 HEAD 请求的 301 代码类似,会自动将请求者转到不同的位置,但您不应使用此代码来告诉 Googlebot 某个网页或网站已经移动,因为 Googlebot 会继续抓取原有位置并编制索引。</p> <p>303(查看其他位置)请求者应当对不同的位置使用单独的 GET 请求来检索响应时,服务器返回此代码。对于除 HEAD 之外的所有请求,服务器会自动转到其他位置。</p> <p>304(未修改)自从上次请求后,请求的网页未修改过。服务器返回此响应时,不会返回网页内容。如果网页自请求者上次请求后再也没有更改过,您应将服务器配置为返回此响应(称为 If-Modified-Since HTTP 标头)。服务器可以告诉 Googlebot 自从上次抓取后网页没有变更,进而节省带宽和开销。</p> <p>305(使用代理)请求者只能使用代理访问请求的网页。如果服务器返回此响应,还表示请求者应使用代理。</p> <p>307(临时重定向)服务器目前从不同位置的网页响应请求,但请求者应继续使用原有位置来响应以后的请求。此代码与响应 GET 和 HEAD 请求的 301 代码类似,会自动将请求者转到不同的位置,但您不应使用此代码来告诉 Googlebot 某个页面或网站已经移动,因为 Googlebot 会继续抓取原有位置并编制索引。</p> <p> 4xx(请求错误):这些状态码表示请求可能出错,妨碍了服务器的处理。</p> <p>400(错误请求)服务器不理解请求的语法。</p> <p>401(未授权)请求要求身份验证。对于登录后请求的网页,服务器可能返回此响应。</p> <p>403(禁止)服务器拒绝请求。如果您在 Googlebot 尝试抓取您网站上的有效网页时看到此状态码(您可以在 Google 网站管理员工具诊断下的网络抓取页面上看到此信息),可能是您的服务器或主机拒绝了 Googlebot 访问。</p> <p>404(未找到)服务器找不到请求的网页。例如,对于服务器上不存在的网页经常会返回此代码。</p> <p>405(方法禁用)禁用请求中指定的方法。</p> <p>406(不接受)无法使用请求的内容特性响应请求的网页。</p> <p>407(需要代理授权)此状态码与 401(未授权)类似,但指定请求者应当授权使用代理。如果服务器返回此响应,还表示请求者应当使用代理。</p> <p>408(请求超时)服务器等候请求时发生超时。</p> <p> 5xx(服务器错误):这些状态码表示服务器在处理请求时发生内部错误。这些错误可能是服务器本身的错误,而不是请求出错。</p> <p>500(服务器内部错误)服务器遇到错误,无法完成请求。</p> <p>501(尚未实施)服务器不具备完成请求的功能。例如,服务器无法识别请求方法时可能会返回此代码。</p> <p>502(错误网关)服务器作为网关或代理,从上游服务器收到无效响应。</p> <p>503(服务不可用)服务器目前无法使用(由于超载或停机维护)。通常,这只是暂时状态。</p> <p>504(网关超时)服务器作为网关或代理,但是没有及时从上游服务器收到请求。</p> <p>505(HTTP 版本不受支持)服务器不支持请求中所用的 HTTP 协议版本。</p> <p> 前端优化方法:</p> <p> 方法分类:</p> <p>降低请求量:合并资源,减少HTTP 请求数,minify / gzip 压缩, webPlazyLoad。</p> <p>加快请求速度:预解析DNS,减少域名数,并行加载,CDN 分发。</p> <p>缓存:HTTP 协议缓存请求,离线缓存 manifest,离线数据缓存localStorage。</p> <p>渲染:JS/CSS优化,加载顺序,服务端渲染,pipeline。</p> <p>具体措施:</p> <p>减少HTTP请求次数:CSS Sprites,js、CSS源码压缩、图片大小控制合适;网页Gzip、CDN托管、data缓存、图片服务器</p> <p>前端模板JS+数据,减少由于HTML标签导致的带宽浪费,前端用变量保存AJAX请求结果,每次操作本地变量,不用请求,减少请求次数</p> <p>用innerHTML替代DOM操作,减少DOM操作次数,优化JavaScript性能。</p> <p>当需要设置的样式很多时,设置className而不是直接操作Style</p> <p>少用全局变量、缓存DOM节点查找的结果。减少IO读取</p> <p>避免使用CSS Expression(css表达式)又称Dynamic properties(动态属性)</p> <p>图片预加载,将样式表放在顶部,将脚本放在底部,加上时间戳。</p> <p>防止内存泄漏:内存泄漏指任何对象在不再拥有或需要它之后仍然继续存在。垃圾回收器定期扫描对象,并计算引用了每个对象的其他的数量。如果一个对象的引用数量为0(没有其他对象引用过该对象),或对该对象的唯一引用是循环的,那么该对象的内存即可回收。</p> <p> 优雅降级与渐进增强:</p> <p> 浏览器输入网址到页面渲染全过程</p> <p>渐进增强:一开始就针对低版本浏览器进行构建页面,完成基本的功能,然后在针对高级浏览器进行效果,交互,追加功能达到更好的体验。</p> <p>优雅降级:一开始就构建站点的完整功能,然后针对浏览器测试和修复,比如一开始使用css3的特性构建一个应用,然后逐步针对各大浏览器进行hack使其可以在低版本浏览器上正常浏览。</p> <p> post和get区别:</p> <p>get参数通过url传递,post参数放在request body中。</p> <p>get请求在url中传递的参数是有长度限制的,而post没有。</p> <p>get比post更不安全,因为参数直接暴露在url中,所以不能用来传递敏感信息。</p> <p>get请求只能进行url编码,而post支持多种编码方式</p> <p>get请求参数会被完整保留在浏览历史记录里,而post中的参数不会被保留。</p> <p>GET和POST本质上就是TCP链接,并无差别。但是由于HTTP的规定和浏览器/服务器的限制,导致他们在应用过程中体现出一些不同。</p> <p>GET产生一个TCP数据包;POST产生两个TCP数据包。对于GET方式的请求,浏览器会把http header和data一并发送出去,服务器响应200(返回数据);而对于POST,浏览器先发送header,服务器响应100 continue,浏览器再发送data,服务器响应200 ok(返回数据)。</p> <p> http与https有什么区别?</p> <p> (1) https协议需要ca申请认证书,一般免费的较少</p> <p>(2) http是超文本传输协议,信息是明文传输,https则是具有安全性的ssl加密传输协议</p> <p>(3) http和https使用的是完全不同的连接方式,用的端口也不一样,前者是80,后者是443</p> <p>(4) http的连接很简单,是无状态的,https协议是由ssl+http协议构建的可进行加密传输,身份认证的网络协议,比http安全</p> <p> HTTP协议中缓存的处理流程:</p> <p> 缓存分为两种:强缓存和协商缓存,根据响应的header内容来决定。</p> <p>强缓存是利用http头中的Expires和cache-Control两个字段来控制的,用来表示资源的缓存时间。强缓存中,普通刷新会忽略它,但不会清除它,需要强制刷新。浏览器强制刷新,请求会带上cache-Control :no-cache和pragma: no-cache</p> <p>协商缓存就是由服务器来确定缓存资源是否可用,所以客户端与服务器端要通过某种标识来进行通信,从而让服务器判断请求资源是否可以缓存访问。</p> <p>普通刷新会启用弱缓存,忽略强缓存。只有在地址栏或收藏夹输入网址、通过链接引用资源等情况下,浏览器才会启用强缓存,这也是为什么有时候我们更新一张图片、一个js文件,页面内容依然是旧的,但是直接浏览器访问那个图片或文件,看到的内容却是新的。这个主要涉及到两组协商缓存相关的header字段:Etag和If-None-Match、Last-Modified和If-Modified-Since。</p> <p>浏览器的缓存过程:</p> <p> 浏览器请求某一资源时,会先获取该资源缓存的header信息,然后根据header中的cache-Control和Expires来判断是否过期。</p> <p>若没过期则直接从缓存中获取资源信息,包括缓存的header的信息,所以此次请求不会与服务器进行通信。这里判断是否过期,则是强缓存相关。</p> <p>如果显示已过期,浏览器会向服务器端发送请求,这个请求会携带第一次请求返回的有关缓存的header字段信息。 比如客户端会通过If-None-Match头将先前服务器端发送过来的Etag发送给服务器,服务会对比这个客户端发过来的Etag是否与服务器的相同, 若相同,就将If-None-Match的值设为false,返回状态304,客户端继续使用本地缓存,不解析服务器端发回来的数据,若不相同就将If-None-Match的值设为true,返回状态为200,客户端重新机械服务器端返回的数据;客户端还会通过If-Modified-since头将先前服务器端发过来的最后修改时间戳发送给服务器,服务器端通过这个时间戳判断客户端的页面是否是最新的,如果不是最新的,则返回最新的内容,如果是最新的,则返回304,客户端继续使用本地缓存。</p> <p>如何解决前端开发中的缓存问题</p> <p>对开发者来说,只要关闭浏览器缓存就可以了,找到network,Disable cache选项,打钩即可取消缓存。</p> <p>开发者可以关闭缓存,但是不能要求所有用户都进行此类操作,此时可以在引用的文件之后拼接随机数或者日期都可以,如css/index.css?v=0.0001,浏览器就会认为是新的请求,而不会使用缓存中的文件。由于每次资源的修改都要更新引用的位置,同时修改参数的值,所以操作起来不是很方便,除非是在动态页面比如jsp中用服务器变量(v=${sysRnd})</p> <p>如果缓存问题出现在ajax请求中,则在ajax请求的地址追加随机数</p> <p>直接ctrl+f5,这个办法能解决页面直接引用的资源更新的问题</p> <p>使用浏览器的隐私模式开发;</p> <p>如果资源引用的页面,被嵌入到了一个iframe里面,可以在iframe的区域右键单击重新加载该页面</p> <p>html5如何及时更新缓存文件(js、css或图片)</p> <p>后端接口页面设置</p> <p> header("Cache-Control: no-cache, must-revalidate"); header("Pragma: no-cache"); 复制代码</p> <p>html页面中设置meta标签的属性(meta标签的http-equiv属性语法格式是:<meta http-equiv="参数" content="参数变量值">)</p> <p> <meta http-equiv="Cache-Control" content="no-cache"> <meta http-equiv="Pragma" content="no-cache">//是用于设定禁止浏览器从本地机的缓存中调阅页面内容,设定后一旦离开网页就无法从Cache中再调出  <meta http-equiv="Expires" content="0"> 复制代码</p> <p>对于图片或css文件,可以在文件名后面添加一个随机数或标志位,例如</p> <p> <link rel="stylesheet" href="./style/style.css?+Math.random()"> 复制代码</p> <p>对于js文件也可以采取3的方法,或者在文件名后使用时间戳</p> <p> <script language="javascript" src="UILib/Common/Common.js?time=new Date()"> 复制代码</p> <p> 输入URL到后发生了什么:</p> <p> 简单过程:</p> <p>DNS域名解析;</p> <p>建立TCP连接;</p> <p>发送HTTP请求;</p> <p>服务器处理请求;</p> <p>返回响应结果;</p> <p>关闭TCP连接;</p> <p>浏览器解析HTML;</p> <p>浏览器布局渲染;</p> <p>详细分析构建请求的过程:</p> <p>应用层进行DNS解析 通过DNS将域名解析成IP地址,在解析过程中,按照浏览器缓存,系统缓存,路由器缓存,ISP(运营商)DNS缓存,根域名服务器,顶级域名服务器,主域名服务器的顺序,逐步读取缓存,直到拿到IP地址。 这里使用DNS预解析,可以根据浏览器定义的规则,提前解析之后可能会用到的域名,使解析结果缓存到系统缓存中,缩短DNS解析时间,来提高网站的访问速度。</p> <p>应用层生成HTTP请求报文 应用层生成针对目标服务器的HTTP报文请求,HTTP请求包括起始行,首部和主体部分。首部包括域名host,keep-alive,User-Agent,Accept-Endoding,Accept-Language,cookie等信息</p> <p>传输层建立TCP连接 http协议使用的TCP协议。 将http请求报文按序号分为多个报文段,并对每个报文段进行封装,使用本地的随机tcp源端口简历到目标服务器的tcp80端口(https是443端口)的连接,TCP源端口和目的端口被加入到报文中。即协议数据单元,同时还会加入序列号,确认号,检验和等参数,共计添加20个字节的头部信息。 这里构建TCP连接请求会增加大量的网络延时。常用的优化方法如下:</p> <p>1)资源打包,合并请求</p> <p>2)多使用缓存,减少网络传输</p> <p>3)使用keep-alive建立持久连接</p> <p>4)使用多个域名,增加浏览器的资源并发加载数,或者使用http2的管道化连接的多路复用技术</p> <p>网络层使用IP协议来选择线路。 处理来自传输层的数据段segment,将数据段segment装入数据包packet,填充包头,主要添加源和目的IP地址,然后发送数据。IP协议负责选择传送的路线,称为路由功能。</p> <p>数据链路层实现网络相邻结点间可靠的数据通信 为了保证数据的可靠性,把数据包packet封装成帧,并按顺序传送各帧,对每个数据块计算CRC(循环冗余检验),防止数据包丢失,出错就重传。 将数据包封装成帧,分为帧头和帧尾,帧尾是CRC校验部分,帧头主要是添加数据链路层的地址,源地址和目的地址,即网络相邻结点间的MAC地址</p> <p>物理层传输数据 将数据链路层的帧转换为二进制形式的比特流,从网卡发送出去,再转换成电子,光学信号在网络中传输。</p> <p> 总结:6个步骤分别为:DNS协议解析URL地址,生成HTTP请求报文,构建TCP链接,使用IP协议选择传输路线,数据链路层保证数据的可靠传输,物理层将数据转换为物理信号进行传输。</p> <p> 补充:服务器处理及反向传输:</p> <p>服务器接收到这个比特流,把比特流转换成帧格式,上传到数据链路层,服务器发现数据帧中的目的MAC地址与本网卡的MAC地址相同,服务器拆除数据链路层的封装后,把数据包上传到网络层。服务器的网络层比较数据包中的目的IP地址,发现与本机的IP地址相同,服务器拆除网络层的封装后,把数据分段上传到传输层。传输层对数据分段进行确认、排序、重组,确保数据传输的可靠性。数据最后被传到服务器的应用层</p> <p>  接着,通过传输层、网络层、数据链路层的层层封装,最终将响应报文封装成二进制比特流,并转换成其他信号,如电信号到网络中传输</p> <p>  反向传输的过程与正向传输的过程类似</p> <p> 浏览器的渲染过程:</p> <p> 主要步骤</p> <p>浏览器将获取到的HTML文档解析成DOM树</p> <p>处理css标记,构成层叠样式表模型CSSOM(css object model)</p> <p>将DOM和CSSOM合并为渲染树(rendering tree),代表一系列将要被渲染的对象</p> <p>渲染树的每个元素包含的内容是计算过的,称之为布局layout,浏览器使用一种流式处理的方法,只需要一次绘制操作就可以布局所有元素</p> <p>将渲染树的各个节点绘制到屏幕上,这一步被称为绘制painting 具体流程:</p> <p> 构建DOM树:</p> <p> 浏览器收到服务器响应来的HTML文档后,遍历文档节点,生成DOM树,DOM树构建时可能会被CSS和JS的加载而执行阻塞,display:none的元素,注释,script也会存在于DOM树中。</p> <p> 构建CSSOM规则树</p> <p> 浏览器解析CSS文件并对每个文件生成一个stylesheet对象,每个对象包含css规则。css解析可以和DOM解析同时进行,css的解析会被js互斥。</p> <p> 构建渲染树(render tree):</p> <p> 浏览器从DOM树的根结点遍历每个可见结点,然后对每个可见结点找到css样式规则并应用。Render tree与DOM tree不完全对应,display:none的元素不在render tree中,visibility:hidden元素在render tree中。这个时候还没渲染到屏幕上,渲染到屏幕需要用到各个节点的位置信息,需要布局的处理</p> <p> 渲染树布局(render tree layout):</p> <p> 布局阶段,遍历每一个render object对象,包含宽高,位置,背景色等样式信息,通过这些信息确定每个结点在页面上的确切位置。脱离文档流,脱离的是render tree</p> <p> 渲染树绘制(render tree paint):</p> <p> 绘制阶段,浏览器遍历渲染树,调用渲染器的paint()方法在屏幕上显示其内容,由浏览器的后端UI组建完成。</p> <p> Js阻塞:</p> <p>JS可以操作DOM来改变DOM结构,修改CSSOM样式,所以浏览器在遇到<script>标签时,DOM构建将暂停,直到脚本执行完成,再继续构建DOM,所以<script>标签一般放在最后。现在可以在<script>标签上增加defer,async等属性,单独解析js中操作DOM和CSSOM的地方追加到DOM和CSSOM上。Css阻塞:</p> <p>CSSOM负责存储渲染信息,所以CSSOM在浏览器合成渲染树之前必须是完备的,否则就不会进入渲染过程。所以将样式放在head中,为了更快的解析css。defer和async属性的区别:</p> <p>没有defer和async属性的时候浏览器在读取到<script>标签的时候会立即读取脚本文件,而不会加载后续的文档元素,会阻塞后续DOM的构建 文档解析时,遇到设置了defer的脚本,就会在后台进行下载,但是并不会阻止文档的渲染,当页面解析&渲染完毕后。会等到所有的defer脚本加载完毕并按照顺序执行,执行完毕后会触发DOMContentLoaded(dom内容加载完毕)事件。 async脚本会在加载完毕后执行。async脚本的加载不计入DOMContentLoaded事件统计 有defer或者async属性之后,脚本文件的读取和后续文档的加载是并行的也就是异步执行,js脚本的执行会等到所有元素被解析完成之后,DOMContentLoaded事件调用前执行。 存在多个defer的脚本文件时,他们会按照顺序defer的顺序执行,而async的加载则是无序的,只要DOM加载完成会立即执行,不考虑脚本之间的依赖关系。</p> <p> 重排(layout)和重绘(repaint):</p> <p> DOM的变化影响到了已渲染完成的几何属性,比如宽高等,浏览器将重新计算元素的几何属性,其他元素的几何属性也会受到影响,浏览器需要重新构造渲染树(Render树),这个过程称之为重排(也叫回流reflow),浏览器将受到影响的部分重新绘制在屏幕上的过程称之为重绘。display:none会触发reflow,而visibility: hidden属性则并不算是不可见属性,只会触发repaint</p> <p> 重绘产生的原因有:</p> <p>添加或删除可见的DOM元素,</p> <p>元素的尺寸位置发生改变。</p> <p>浏览器页面初始化</p> <p>浏览器窗口大小发生变化</p> <p>重排一定导致重绘,重绘不一定导致重排。</p> <p>减少重绘重排的方法:</p> <p>不在布局信息改变时做DOM查询</p> <p>不要一条一条的修改DOM样式,使用csstext,className一次性改变属性</p> <p>在内存中多次操作节点,完成后再添加到文档中</p> <p>对于一个元素进行复杂的操作时,先隐藏,操作完再展示</p> <p>需要经常获取那些引起浏览器重排的属性时,缓存到变量中</p> <p>不要使用table布局,一个小改动会导致table重新布局</p> <p>对于多次重排的元素,比如说动画,使用绝对定位让其脱离文档流,使其不影响其他元素,减少重绘范围</p> <p> http报文构成:</p> <div class="image-package"> <div class="image-container" style="max-width: 576px; max-height: 267px;"> <div class="image-view"> <a href="http://img.e-com-net.com/image/info10/c14052951c6540638cc1f57104223082.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info10/c14052951c6540638cc1f57104223082.jpg" width="576" height="267" alt="2020秋招前端面经知识点汇总(一) html,css部分_第5张图片" style="border:1px solid black;"></a> </div> </div> <div class="image-caption"></div> </div> <div class="image-package"> <div class="image-container" style="max-width: 686px; max-height: 249px;"> <div class="image-view"> <a href="http://img.e-com-net.com/image/info10/3e406a902e224db1b8d97f212842d8d8.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info10/3e406a902e224db1b8d97f212842d8d8.jpg" width="650" height="236" alt="2020秋招前端面经知识点汇总(一) html,css部分_第6张图片" style="border:1px solid black;"></a> </div> </div> <div class="image-caption"></div> </div> <p> 使用HTTP长连接有哪些优点:</p> <p> HTTP长连接(持久化连接):  在一个TCP连接的基础之上,发送多个HTTP请求以及接收多个HTTP响应,这是为了避免每一次请求都去打开一个新的连接。</p> <p>在HTTP/1.0中默认使用短连接。也就是说,客户端和服务器每进行一次HTTP操作,就建立一次连接,任务结束就中断连接。 而从HTTP/1.1起,默认使用长连接,用以保持连接特性。使用长连接的HTTP协议,会在响应头加入这行代码:Connection:keep-alive 在使用长连接的情况下,当一个网页打开完成后,客户端和服务器之间用于传输HTTP数据的TCP连接不会关闭,客户端再次访问这个服务器时,会继续使用这一条已经建立的连接。</p> <p>Keep-Alive不会永久保持连接,它有一个保持时间,可以在不同的服务器软件(如Apache)中设定这个时间。实现长连接需要客户端和服务端都支持长连接。</p> <p>HTTP协议的长连接和短连接,实质上是TCP协议的长连接和短连接。</p> <p> 长连接的特点:</p> <p> 可以省去较多的TCP连接建立和关闭的操作,减少浪费,节约时间。适用于频繁请求服务器资源的客户端之间建立。</p> <p> 短连接的特点:</p> <p> 对于服务器来说管理较为简单,存在的连接都是有用的连接,但是如果客户请求频繁,将在TCP的建立和关闭操作上浪费时间和带宽。WEB网站的http服务一般采用的都是短连接服务。</p> <p> 客户端和服务器之间的连接如果一直不关闭,随着建立连接的客户端越来越多,会增加服务器的压力,所以一般采取以下几种策略:</p> <p>1.关闭一些长时间没有发生读写事件的连接。</p> <p>2.限制每个客户端的最大长连接数量。</p> <p> TLS/SSL协议是如何保障信息安全的:</p> <p> SSL(安全套接字协议):是web浏览器和web服务器之间安全交换信息的协议,提供两个基本的安全服务,鉴别和保密 TLS(安全传输层协议):用于在两个通信应用程序之间提供保密性和数据完整性。其中TLS是SSL的升级版</p> <p> SSL/TLS协议的基本过程</p> <p> (1) 客户端向服务器端索要并验证公钥。</p> <p>(2) 双方协商生成"对话密钥"。</p> <p>(3) 双方采用"对话密钥"进行加密通信。具体过程可细分为8个步骤:</p> <p>客户端向服务器发起https请求,连接到服务器的443端口</p> <p>服务器有密钥对,即公钥和私钥,用来进行非对称加密</p> <p>服务器将公钥发送给客户端</p> <p>客户端收到服务端的数据后,先验证其证书的合法性,如果合法,客户端生成客户端密钥,并使用服务端接收到的公钥对客户端密钥进行加密。</p> <p>客户端再次发起https请求,将加密之后的客户端密钥发送给服务器</p> <p>服务器接收到客户端发送过来的加密后的密钥,用自己的私钥进行解密,然后用客户端密钥对要发送的数据进行加密。</p> <p>将加密后的数据发送给客户端</p> <p>客户端使用客户端密钥对加密数据进行解密,得到服务器发送的数据。SSL协议的内容:</p> <p>握手协议 握手协议是客户端和服务器用SSL连接通信时使用的第一个子协议,握手协议包括客户机与服务器之间的一系列消息,是SSL协议中最复杂的协议,该协议允许服务器和客户机相互验证,协商加密和MAC算法(带秘密密钥的Hash函数)及保密密钥,用来保护在SSL记录中发送的数据,握手协议是在应用程序的数据传输之前使用的。 1.1 建立安全能力,发送信息,交换版本,随机数,会话ID,密码套件,压缩方法等信息 1.2 服务器鉴别与密钥交换 1.3 客户机鉴别与密钥交换 1.4 完成</p> <p>记录协议 记录协议在客户机和服务器成功握手之后使用,即客户机和服务器鉴别对方和确定安全信息交换使用的算法后,进入SSL记录协议。</p> <p>警报协议 客户机和服务器发现错误时,向对方发送一个警报信息,如果是致命错误,则算法立即关闭SSL连接,双方删除相关的会话号,密钥等。</p> <p> 总结:SSL中,使用握手协议协商加密和MAC算法以及保密密钥,使用握手协议对交换的数据进行加密和签名,使用警报协议定义数据传输过程中,出现问题改如何解决。</p> <p> HTTP 1.0,1.1,2.0协议的区别:</p> <p> HTTP1.0 HTTP 1.1主要区别长连接HTTP 1.0需要使用keep-alive参数来告知服务器端要建立一个长连接,而HTTP1.1默认支持长连接。</p> <p>HTTP是基于TCP/IP协议的,创建一个TCP连接是需要经过三次握手的,有一定的开销,如果每次通讯都要重新建立连接的话,对性能有影响。因此最好能维持一个长连接,可以用个长连接来发多个请求。节约带宽HTTP 1.1支持只发送header信息(不带任何body信息),如果服务器认为客户端有权限请求服务器,则返回100,否则返回401。客户端如果接受到100,才开始把请求body发送到服务器。</p> <p>这样当服务器返回401的时候,客户端就可以不用发送请求body了,节约了带宽。</p> <p>另外HTTP还支持传送内容的一部分。这样当客户端已经有一部分的资源后,只需要跟服务器请求另外的部分资源即可。这是支持文件断点续传的基础。HOST域现在可以web server例如tomat,设置虚拟站点是非常常见的,也即是说,web server上的多个虚拟站点可以共享同一个ip和端口。</p> <p>HTTP1.0是没有host域的,HTTP1.1才支持这个参数。</p> <p> HTTP1.1 HTTP 2.0主要区别多路复用HTTP2.0使用了(类似epoll)多路复用的技术,做到同一个连接并发处理多个请求,而且并发请求的数量比HTTP1.1大了好几个数量级。</p> <p>当然HTTP1.1也可以多建立几个TCP连接,来支持处理更多并发的请求,但是创建TCP连接本身也是有开销的。</p> <p>TCP连接有一个预热和保护的过程,先检查数据是否传送成功,一旦成功过,则慢慢加大传输速度。因此对应瞬时并发的连接,服务器的响应就会变慢。所以最好能使用一个建立好的连接,并且这个连接可以支持瞬时并发的请求。数据压缩HTTP1.1不支持header数据的压缩,HTTP2.0使用HPACK算法对header的数据进行压缩,这样数据体积小了,在网络上传输就会更快。</p> <p>请求与响应首部的定义在HTTP2.0中基本没有变,只是所有首部键必须全部小写,而且要求行要独立为:method:、:scheme:、:host:、:path:这些键值对</p> <p>对于相同的数据,不再重新通过每次请求和响应发送。每个新的首部键值对要么追加到当前表的末尾,要么替换表中之前的值。首部表在HTTP2.0的链接存续期内始终存在,由客户端和服务端共同渐进的更新。服务器推送意思是说,当我们对支持HTTP2.0的web server请求数据的时候,服务器会顺便把一些客户端需要的资源一起推送到客户端,免得客户端再次创建连接发送请求到服务器端获取。这种方式非常合适加载静态资源。</p> <p>服务器端推送的这些资源其实存在客户端的某处地方,客户端直接从本地加载这些资源就可以了,不用走网络,速度自然是快很多的。二进制帧层HTTP2.0会把所有信息分割成更小的消息和帧,并采用二进制格式将其封装。例如header封装到Headers帧,request body封装到Data帧。</p> <p>HTTP2.0通信都在一个TCP连接上完成,这个连接可以承载任意数量的双向数据流,相应的每个数据流以消息的形式发送。而消息由一或多个帧组成,这些帧可以乱序发送,然后根据每个帧首部的流标识符重新组装。</p> <p> WebSocket协议:</p> <p> ajax轮询ajax(异步的javascript与xml技术)是一种有效利用javascript和dom的操作,以达到局部web页面的提花和加载的异步通信手段。和以前的同步通信相比,他只更新一部分页面,相应中传输的数据量会因此的减少。</p> <p> ajax轮询的原理是,让浏览器每隔一段时间就发送一次请求,询问服务器是否有新消息。而利用ajax实时的从服务器获取内容,有可能导致大量的请求产生。</p> <p> 长轮询原理和ajax轮询差不多,都是采用轮询的方式,不过采用的是阻塞模型。也就是说,当客户端发起连接后,如果服务器端内容没有更新,将响应至于挂起状态,一直不回复response给客户端,知道有内容更新,再返回响应。</p> <p>http的特点:被动性,请求只能由客户端发起。服务器端不能主动联系客户端。</p> <p>ajax轮询 需要服务器有很快的处理速度和资源。(速度)</p> <p>长轮询 需要有很高的并发,也就是说同时接待客户的能力。(场地大小)WebSocket</p> <p>WebSocket是HTML5出的东西(协议),是HTML5开始提供的一种浏览器与服务器进行全双工通讯的网络技术,属于应用层协议。它基于TCP传输协议,并复用HTTP的握手通道。</p> <p>一旦web服务器和客户端建立起websocket协议的通信连接,之后所有的通信都依靠这个专用连接进行。只需要经过一次HTTP请求,就可以做到源源不断的信息传送了。</p> <p>通过在请求首部中设置Connection: Upgrade来使用websocket协议</p> <p>websocket协议具有以下的特点推送功能支持服务器端向客户端推送功能。服务器可以直接发送数据而不用等待客户端的请求。减少通信量只要建立起websocket连接,就一直保持连接,在此期间可以源源不断的传送消息,直到关闭请求。也就避免了HTTP的非状态性。</p> <p>和http相比,不但每次连接时的总开销减少了,而且websocket的首部信息量也小 ,通信量也减少了。</p> <p>支持双向通信,实时性更强。更好的二进制支持。较少的控制开销。</p> <p>连接创建后,ws客户端、服务端进行数据交换时,协议控制的数据包头部较小。在不包含头部的情况下,服务端到客户端的包头只有2~10字节(取决于数据包长度),客户端到服务端的的话,需要加上额外的4字节的掩码。而HTTP协议每次通信都需要携带完整的头部。支持扩展ws协议定义了扩展,用户可以扩展协议,或者实现自定义的子协议。(比如支持自定义压缩算法等)</p> <p> CSS部分:</p> <p> css3新增:</p> <p> CSS3边框如border-radius,box-shadow等;CSS3背景如background-size,background-origin等;CSS3 2D,3D转换如transform等;CSS3动画如animation等。</p> <p>CSS3的新特性中,在布局方面新增了flex布局,在选择器方面新增了例如first-of-type,nth-child等选择器,在盒模型方面添加了box-sizing来改变盒模型,在动画方面增加了animation,2d变换,3d变换等,在颜色方面添加透明,rbga等,在字体方面允许嵌入字体和设置字体阴影,最后还有媒体查讯等.</p> <p> css的两种盒模型</p> <div class="image-package"> <div class="image-container" style="max-width: 449px; max-height: 285px;"> <div class="image-view"> <a href="http://img.e-com-net.com/image/info10/d3c197626db3443eb00951ecb98071e2.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info10/d3c197626db3443eb00951ecb98071e2.jpg" width="449" height="285" alt="2020秋招前端面经知识点汇总(一) html,css部分_第7张图片" style="border:1px solid black;"></a> </div> </div> <div class="image-caption"></div> </div> <p> 在标准的盒子模型中,width指content部分的宽度</p> <div class="image-package"> <div class="image-container" style="max-width: 451px; max-height: 275px;"> <div class="image-view"> <a href="http://img.e-com-net.com/image/info10/0bb103337ea64411ae5ce954d3777d56.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info10/0bb103337ea64411ae5ce954d3777d56.jpg" width="451" height="275" alt="2020秋招前端面经知识点汇总(一) html,css部分_第8张图片" style="border:1px solid black;"></a> </div> </div> <div class="image-caption"></div> </div> <p> 在IE盒子模型中,width表示content+padding+border这三个部分的宽度</p> <p>如果想要切换盒模型也很简单,这里需要借助css3的box-sizing属性</p> <p>box-sizing: content-box 是W3C盒子模型</p> <p>box-sizing: border-box 是IE盒子模型</p> <p>box-sizing的默认属性是content-box</p> <p> 垂直居中方式:</p> <p>使用定位和负外边距,父元素,子元素固定宽高,父相子绝,子元素top属性50%,上外边距margin-top为子元素本身高度的一半(这种方式需要知道子元素的高度)</p> <p>使用定位和transform,父元素固定宽高,父相子绝,子元素top属性50%,transform属性为Y轴方向偏移-50%</p> <p>使用定位自动外边距,父元素,子元素固定宽高,父相子绝,子元素top,bottom属性为0,margin在垂直方向auto</p> <p>使用flex布局,父元素,子元素固定宽高,父元素使用flex布局,设置align-items属性为center</p> <p>使用flex布局,父元素,子元素固定宽高,父元素使用flex布局,设置flex-direction属性(设置主轴方向)为column(纵轴),justify-content属性设置主轴上的对齐方式为center</p> <p>使用 display:table-cell ,父元素固定宽高,父元素设置display:table,子元素设置display:table-cell,并且vertical-align:middle</p> <p> transition和animation的区别:</p> <p> animation和transition大部分属性是相同的,他们都是随时间改变元素的属性值,他们的主要区别是transition需要触发一个事件才能改变属性,而animation不需要触发任何事件的情况下才会随时间改变属性值,并且transition为2帧,从from .... to,而animation可以一帧一帧的。</p> <p> animation属性</p> <p>name 设置动画的名称,</p> <p>duration 设置动画完成的周期,</p> <p>timing-function 设置动画的速度曲线,</p> <p>delay 设置动画什么时候开始,</p> <p>iteration-count 设置动画播放的次数,</p> <p>direction 规定下一个周期是否逆向的播放,</p> <p>play-state 动画是否正在进行或者暂停,</p> <p>fill-mode 设置动画停了之后位置什么状态transition属性</p> <p>property 去设置过渡效果的属性名称,</p> <p>duration 设置过渡效果的周期,</p> <p>timing-function 规定速度效果的速度曲线,</p> <p>delay 设定过渡效果什么时候开始;区别:</p> <p>transition 是过渡,是样式值的变化的过程,只有开始和结束;animation 其实也叫关键帧,通过和 @keyframe 结合可以设置中间帧的一个状态;</p> <p>animation 配合 @keyframe 可以不触发事件就触发这个过程,而 transition 需要通过 hover 或者 js 事件来配合触发;</p> <p>animation 可以设置很多的属性,比如循环次数,动画结束的状态等等,transition 只能触发一次;</p> <p>animation 可以结合 keyframe 设置每一帧,但是 transition 只有两帧;</p> <p>在性能方面:浏览器有一个主线程和排版线程;主线程一般是对 js 运行的、页面布局、生成位图等等,然后把生成好的位图传递给排版线程,而排版线程会通过 GPU 将位图绘制到页面上,也会向主线程请求位图等等;我们在用使用 animation 的时候这样就可以改变很多属性,像我们改变了 width、height、position 等等这些改变文档流的属性的时候就会引起,页面的回流和重绘,对性能影响就比较大,但是我们用 transition 的时候一般会结合 transform 来进行旋转和缩放等不会生成新的位图,当然也就不会引起页面的重排了;</p> <p> transition、transform和translate这三者</p> <p> transform是转换,指的是改变所在元素的外观,它有很多种手段(转换函数)来改变外观,例如 位移、缩放、旋转等,而其中的位移的函数名就叫translate,所以说,translate是transform的一部分。</p> <p>transform: [转换函数];</p> <p>属性函数:</p> <p>translate(x, y):元素位移,元素偏移的x轴和y轴距离,可为负</p> <p>scale(x, y):元素缩放,元素x轴和y轴缩放的倍数,小于1为缩小,大于1位放大,小于0效果和为0时相等</p> <p>rotate(angle):元素旋转,旋转的角度,单位deg,顺时针旋转</p> <p> transform: translate(-10px, 10px);//当前元素往上移动 10 像素,往右移动 10 像素。 transform: translate(10px, 10px) rotate(10deg);//指定多个转换效果。 复制代码</p> <p> transition是过渡,指的是某个CSS属性值如何平滑的进行改变,就是平常说的 动效。而transform是没有动画效果,你改变了它的值,元素的样子就唰的改变了。</p> <p> transition: [属性名] [持续时间] [速度曲线] [延迟时间]; transition: height 2s ease .5s;//高度属性的值改变时,延迟 0.5 秒后以 ease 曲线进行过渡,持续2秒。 复制代码</p> <p> visibility=hidden, opacity=0,display:none:</p> <p>opacity=0,该元素隐藏起来了,但不会改变页面布局,并且,如果该元素已经绑定一些事件,如click事件,那么点击该区域,也能触发点击事件的方法。</p> <p>visibility=hidden,该元素隐藏起来了,但不会改变页面布局,但是不会触发该元素已经绑定的事件。</p> <p>display=none,把元素隐藏起来,并且会改变页面布局,可以理解成在页面中把该元素删除掉一样。</p> <p> position属性比较:</p> <p> 固定定位fixed:</p> <p>元素的位置相对于浏览器窗口是固定位置,即使窗口是滚动的它也不会移动。Fixed定位使元素的位置与文档流无关,因此不占据空间。 Fixed定位的元素和其他元素重叠。</p> <p> 相对定位relative:相对于他原本的位置进行移动</p> <p>如果对一个元素进行相对定位,它将出现在它所在的位置上。然后,可以通过设置垂直或水平位置,让这个元素“相对于”它的起点进行移动。 在使用相对定位时,无论是否进行移动,元素仍然占据原来的空间。因此,移动元素会导致它覆盖其它框。</p> <p> 绝对定位absolute:相对于他的父元素进行移动</p> <p>绝对定位的元素的位置相对于最近的已定位父元素,如果元素没有已定位的父元素,那么它的位置相对于<html>。 absolute 定位使元素的位置与文档流无关,因此不占据空间。 absolute 定位的元素和其他元素重叠。</p> <p> 粘性定位sticky:</p> <p>先是相对于他原本的位置进行移动,然后在超出目标区域后,固定在目标位置,即先按照relative定位方式定位,然后按照fix定位方式定位。 元素先按照普通文档流定位,然后相对于该元素在流中的flow root(BFC)和 containing block(最近的块级祖先元素)定位。而后,元素定位表现为在跨越特定阈值前为相对定位,之后为固定定位。</p> <p> 默认定位Static:</p> <p>默认值。没有定位,元素出现在正常的流中(忽略top, bottom, left, right 或者 z-index 声明)。</p> <p> 继承定位inherit:</p> <p>规定应该从父元素继承position 属性的值。</p> <p> 浮动清除的几种方法:</p> <p> 方法一:使用带clear属性的空元素</p> <p>在浮动元素后使用一个空元素如<div class="clear"></div>,并在CSS中赋予.clear{clear:both;}属性即可清理浮动。亦可使用<br class="clear" />或<hr class="clear" />来进行清理。</p> <p> 方法二:使用CSS的overflow属性</p> <p>给浮动元素的容器添加overflow:hidden;或overflow:auto;可以清除浮动,另外在 IE6 中还需要触发 hasLayout ,例如为父元素设置容器宽高或设置 zoom:1。</p> <p>在添加overflow属性后,浮动元素又回到了容器层,把容器高度撑起,达到了清理浮动的效果。</p> <p> 方法三:给浮动的元素的容器添加浮动</p> <p>给浮动元素的容器也添加上浮动属性即可清除内部浮动,但是这样会使其整体浮动,影响布局,不推荐使用。</p> <p> 方法四:使用邻接元素处理</p> <p>什么都不做,给浮动元素后面的元素添加clear属性。</p> <p> 方法五:使用CSS的:after伪元素</p> <p>结合:after 伪元素(注意这不是伪类,而是伪元素,代表一个元素之后最近的元素)和 IEhack ,可以完美兼容当前主流的各大浏览器,这里的 IEhack 指的是触发 hasLayout。</p> <p>给浮动元素的容器添加一个clearfix的class,然后给这个class添加一个:after伪元素实现元素末尾添加一个看不见的块元素(Block element)清理浮动。</p> <p> CSS选择器有哪些,优先级呢:</p> <p> CSS的四种基本选择器和四种高级选择器:</p> <p> 基本选择器:</p> <p> 标签选择器:针对一类标签</p> <p>P{}:选择所有<p>元素</p> <p> ID选择器:针对某一个特定的标签使用</p> <p>#id{}:选择所有id="firstname"的元素</p> <p> 类选择器:针对你想要的所有标签使用</p> <p>.class{}:选择所有class="intro"的元素</p> <p> 通用选择器(通配符):针对所有的标签都适用(不建议使用)</p> <p>:选择所有元素</p> <p> 高级选择器:</p> <p> 后代选择器:用空格隔开</p> <p>div p: 选择<div>元素内的所有<p>元素</p> <p>div>p: 选择所有父级是 <div> 元素的 <p> 元素</p> <p>div+p: 选择所有紧接着<div>元素之后的<p>元素</p> <p> 属性选择器:带有属性或指定属性内容</p> <p>[target]:选择所有带有target属性元素</p> <p>[target=-blank]:选择所有使用target="-blank"的元素</p> <p>[title~=flower]:选择标题属性包含单词"flower"的所有元素</p> <p>[lang|=en]:选择 lang 属性以 en 为开头的所有元素</p> <p> 交集选择器:用.隔开</p> <p>h3.special:选择<h3>标签并且类是.special的标签</p> <p> 并集选择器(分组选择器):用逗号隔开</p> <p>div,p: 选择所有<div>元素和<p>元素</p> <p>p,h1,#mytitle,.one:选择所有带有p,h1,id="mytitle",class="one"的标签</p> <p> 伪类选择器:</p> <p>静态伪类选择器:</p> <p>a:link:选择所有未访问链接</p> <p>a:visited:选择所有访问过的链接</p> <p>动态伪类选择器:</p> <p>a:active:选择活动链接</p> <p>a:hover:选择鼠标在链接上面时</p> <p>input:focus:选择具有焦点的输入元素</p> <p>序伪类选择器:</p> <p>p:first-letter:选择每一个p元素的第一个字母</p> <p>p:first-line:选择每一个p元素的第一行</p> <p>p:first-child:指定只有当p元素是其父级的第一个子级的样式。</p> <p>p:before:在每个p元素之前插入内容</p> <p>p:after:在每个p元素之后插入内容</p> <p> Css3新增选择器: p~ul:选择p元素之后的每一个ul元素</p> <p>a[src^"ttps"]:选择每一个src属性的值以"https "开头的元素</p> <p>a[src$=". pdf"]:选择每一个src属性的值以” pdf结尾的元素</p> <p>a[src*=" runoob"]:选择每一个src属性的值包含子字符串" 'runoob"的元素</p> <p>p:first-of-type:选择每个p元素是其父级的第一个p元素</p> <p>p:last-of-type:选择每个p元素是其父级的最后一个p元素</p> <p>p:only-of-type:选择每个p元素是其父级的唯一p元素</p> <p>p:only-child:选择每个p元素是其父级的唯一子元素</p> <p>p:nth-child(2):选择每个p元素是其父级的第二个子元素</p> <p>p::nth-child(-n+3):选择每个p元素是其父级的前三个子元素</p> <p>p:th-last-child(2):选择每个p元素的是其父级的第二个子元素,从最后一个子项计数</p> <p>p:th-of-type(2):选择每个p元素是其父级的第二个p元素</p> <p>p:nth-last-of-type(2):选择每个p元素的是其父级的第二个p元素, 从最后一个子项计数</p> <p>p:last-child:选择每个p元素是其父级的最后-个子级。</p> <p>.root:选择文档的根元素</p> <p>p:empty:选择每个没有任何子级的p元素(包括文本节点)</p> <p>#news:target:选择当前活动的#news元素(包含该锚名称的点击的URL)</p> <p>inputenabled:选择每一个已启用的输入元素</p> <p>input:disabled:选择每一个禁用的输入元素</p> <p>input.checked:选择每个选中的输入元素</p> <p>:not(p):选择每个并非p元素的元素</p> <p>:selection:匹配元素中被用户选中或处于高亮状态的部分</p> <p>:out-of-range:匹配值在指定区间之外的input元素</p> <p>:in-range:匹配值在指定区间之内的input元素</p> <p>.read-write:用于匹配可读及可写的元素</p> <p>:read-only:用于匹配设置"readonly" (只读)属性的元素</p> <p>:optional:用于匹配可选的输入元素</p> <p>.required:用于匹配设置了"required" 属性的元素</p> <p>valid:用于匹配输入值为台法的元素</p> <p>cinvalid:用于匹配输入值为非法的元素</p> <p> Css选择器优先级:</p> <p>在属性后面使用 !important 会覆盖页面内任何位置定义的元素样式。</p> <p>作为style属性写在元素内的样式</p> <p>id选择器</p> <p>类选择器</p> <p>元素选择器</p> <p>通配符选择器</p> <p>浏览器自定义或继承</p> <p> margin塌陷和合并问题:</p> <p> 首先,margin塌陷是相对于父子级关系的两个元素,而margin合并是相对两个兄弟级关系的两个元素</p> <p> 两个兄弟级关系的元素,垂直方向上的margin,其外边距会发生重叠现象,两者两个的外边距取的是两个所设置margin的最大值,就是所说的margin合并问题</p> <p> 两个父子级关系的元素,垂直方向上的margin会粘合在一起,外层和模型的margin-top取两个元素中margin-top的最大值,发生margin塌陷的内层元素相对于整个文档移动</p> <p>解决方案:两者都可以通过触发BFC来解决</p> <p> 什么是BFC:</p> <p> 直译成:块级格式化上下文,是一个独立的渲染区域,并且有一定的布局规则。</p> <p>BFC区域不会与float box重叠。</p> <p>BFC是页面上的一个独立容器,子元素不会影响到外面。</p> <p>计算BFC的高度时,浮动元素也会参与计算。</p> <p>并且在一个BFC中,块盒与行盒(行盒由一行中所有的内联元素所组成)都会垂直的沿着其父元素的边框排列。</p> <p> 哪些元素会生成BFC:</p> <p>float不为none的元素</p> <p>position为fixed和absolute的元素</p> <p>display为inline-block、table-cell、table-caption,flex,inline-flex的元素</p> <p>overflow不为visible的元素</p> <p> inline-block、inline和block的区别:</p> <p>Block是块级元素,其前后都会有换行符,能设置宽度,高度,margin/padding水平垂直方向都有效。</p> <p>Inline:设置width和height无效,margin在竖直方向上无效,padding在水平方向垂直方向都有效,前后无换行符</p> <p>Inline-block:能设置宽度高度,margin/padding水平垂直方向 都有效,前后无换行符</p> <p> px、em、rem、%、vw、vh、vm这些单位的区别</p> <p>em:参考的是父元素的font-size,具有继承的特点,如果自身定义了font-size则按自身来计算(浏览器默认字体是16px),整个页面内1em不是一个固定的值</p> <p>rem:相对于根元素html,可以设置根元素html的font-size为10px,则1.2em就是12px;</p> <p>vw:css3新单位,view width的缩写,是指可视窗口的高度,假如宽度是1200px,则10vw就是120px;举个例子:浏览器宽度1200px, 1 vw = 1200px/100 = 12 px。</p> <p>Vh:类似vw,指的是可视窗口的高度。</p> <p>Vm:相对于视口的宽度或高度中较小的那个,其中最小的单位被均分为100个单位,举个例子:浏览器高度900px,宽度1200px,取最小的浏览器高度,1 vm = 900px/100 = 9 px。</p> <p> flex布局:</p> <p> 常用的Flex属性:</p> <p> display:指定 HTML 元素盒子类型。</p> <p> flex-direction:指定了弹性容器中子元素的排列方式</p> <p>row:横向从左到右排列(左对齐),默认的排列方式。</p> <p>row-reverse:反转横向排列(右对齐,从后往前排,最后一项排在最前面。</p> <p>column:纵向排列。</p> <p>column-reverse:反转纵向排列,从后往前排,最后一项排在最上面。</p> <p> justify-content:设置弹性盒子元素在主轴(横轴)方向上的对齐方式。</p> <p>flex-start:弹性项目向行头紧挨着填充。这个是默认值。第一个弹性项的main-start外边距边线被放置在该行的main-start边线,而后续弹性项依次平齐摆放。</p> <p>flex-end:弹性项目向行尾紧挨着填充。第一个弹性项的main-end外边距边线被放置在该行的main-end边线,而后续弹性项依次平齐摆放。</p> <p>center:弹性项目居中紧挨着填充。(如果剩余的自由空间是负的,则弹性项目将在两个方向上同时溢出)。</p> <p>space-between:弹性项目平均分布在该行上。如果剩余空间为负或者只有一个弹性项,则该值等同于flex-start。否则,第1个弹性项的外边距和行的main-start边线对齐,而最后1个弹性项的外边距和行的main-end边线对齐,然后剩余的弹性项分布在该行上,相邻项目的间隔相等。</p> <p>space-around:弹性项目平均分布在该行上,两边留有一半的间隔空间。如果剩余空间为负或者只有一个弹性项,则该值等同于center。否则,弹性项目沿该行分布,且彼此间隔相等(比如是20px),同时首尾两边和弹性容器之间留有一半的间隔(1/2*20px=10px)。</p> <p> align-items:设置弹性盒子元素在侧轴(纵轴)方向上的对齐方式。</p> <p>flex-start:弹性盒子元素的侧轴(纵轴)起始位置的边界紧靠住该行的侧轴起始边界。</p> <p>flex-end:弹性盒子元素的侧轴(纵轴)起始位置的边界紧靠住该行的侧轴结束边界。</p> <p>center:弹性盒子元素在该行的侧轴(纵轴)上居中放置。(如果该行的尺寸小于弹性盒子元素的尺寸,则会向两个方向溢出相同的长  + 度)。</p> <p>baseline:如弹性盒子元素的行内轴与侧轴为同一条,则该值与'flex-start'等效。其它情况下,该值将参与基线对齐。</p> <p>stretch:如果指定侧轴大小的属性值为'auto',则其值会使项目的边距盒的尺寸尽可能接近所在行的尺寸,但同时会遵照'min/max-width/height'属性的限制。</p> <p> flex-wrap:设置弹性盒子的子元素超出父容器时是否换行。</p> <p>nowrap - 默认, 弹性容器为单行。该情况下弹性子项可能会溢出容器。</p> <p>wrap - 弹性容器为多行。该情况下弹性子项溢出的部分会被放置到新行,子项内部会发生断行</p> <p>wrap-reverse -反转 wrap 排列。</p> <p> align-content:修改 flex-wrap 属性的行为,类似 align-items, 但不是设置子元素对齐,而是设置行对齐。</p> <p>stretch - 默认。各行将会伸展以占用剩余的空间。</p> <p>flex-start - 各行向弹性盒容器的起始位置堆叠。</p> <p>flex-end - 各行向弹性盒容器的结束位置堆叠。</p> <p>center -各行向弹性盒容器的中间位置堆叠。</p> <p>space-between -各行在弹性盒容器中平均分布。</p> <p>space-around - 各行在弹性盒容器中平均分布,两端保留子元素与子元素之间间距大小的一半。</p> <p> flex-flow:flex-direction 和 flex-wrap 的简写</p> <p> order:设置弹性盒子的子元素排列顺序。</p> <p>integer:用整数值来定义排列顺序,数值小的排在前面。可以为负值。</p> <p> align-self:在弹性子元素上使用。覆盖容器的 align-items 属性。</p> <p>auto:如果'align-self'的值为'auto',则其计算值为元素的父元素的'align-items'值,如果其没有父元素,则计算值为'stretch'。</p> <p>flex-start:弹性盒子元素的侧轴(纵轴)起始位置的边界紧靠住该行的侧轴起始边界。</p> <p>flex-end:弹性盒子元素的侧轴(纵轴)起始位置的边界紧靠住该行的侧轴结束边界。</p> <p>center:弹性盒子元素在该行的侧轴(纵轴)上居中放置。(如果该行的尺寸小于弹性盒子元素的尺寸,则会向两个方向溢出相同的长度)。</p> <p>baseline:如弹性盒子元素的行内轴与侧轴为同一条,则该值与'flex-start'等效。其它情况下,该值将参与基线对齐。</p> <p>stretch:如果指定侧轴大小的属性值为'auto',则其值会使项目的边距盒的尺寸尽可能接近所在行的尺寸,但同时会遵照'min/max-width/height'属性的限制。</p> <p> flex:设置弹性盒子的子元素如何分配空间。</p> <p>auto: 计算值为 1 1 auto</p> <p>initial: 计算值为 0 1 auto</p> <p>none:计算值为 0 0 auto</p> <p>inherit:从父元素继承</p> <p>[ flex-grow ]:定义弹性盒子元素的扩展比率。</p> <p>[ flex-shrink ]:定义弹性盒子元素的收缩比率。</p> <p>[ flex-basis ]:定义弹性盒子元素的默认基准值。</p> <p> 流式布局与响应式布局的区别:</p> <p> 常用的Flex属性:</p> <p>流式布局:使用非固定像素来定义网页内容,也就是百分比布局,通过盒子的度设置成百分比来根据屏幕的宽度来进行伸缩,不受固定像素的限制,内容自动填充。</p> <p>响应式布局,利用css3中的Media Query(媒介查询),通过查询screen的宽度来指定某个宽度区间的网页布局 超小屏幕(移动设备):768px以下 小屏设备:768px-992px;</p> <p>中屏设备:992-1200px;</p> <p>宽屏设备:1200px以上</p> <p>由于响应式布局开发显得繁琐,一般使用第三方响应式框架来完成,比如bootstrap来完成一部分工作</p> <p> 三栏布局的实现方式:</p> <p> 常用的Flex属性:</p> <p>浮动</p> <p>三栏设置高度,左右栏固定宽度,并分别设置左右浮动</p> <p>优点:兼容性好</p> <p>缺点:浮动脱离文档流,需要做清除浮动的处理</p> <p>绝对定位</p> <p>父级元素设置绝对定位,左右栏固定宽度,左栏设置left:0;右栏设置right:0;中间栏设置left和right分别为左右栏的宽度</p> <p>优点:快捷,不容易出问题</p> <p>缺点:布局脱离文档流,子元素也必须脱离文档流,可使用性较差</p> <p>Flex布局</p> <p>父元素设置display:flex,左右栏固定宽度,中间栏设置flex:1,占据剩余空间</p> <p>优点:较为完美,移动端布局多属flex</p> <p>表格布局</p> <p>父元素设置display:table,左右中三栏全部设置display:table-cell,左右栏固定宽度</p> <p>优点:兼容性好</p> <p>缺点:操作繁琐,当其中一个单元格高度变大,其他单元格高度会随之变大</p> <p>网格布局</p> <p>父元素设置display:grid,固定宽度,grid-template-rows: 100px;grid-template-columns: 300px auto 300px;优点:可以做许多复杂的事情,代码比较简洁</p> <p>缺点:新技术,低版本浏览器兼容性不好</p> </article> </div> </div> </div> <!--PC和WAP自适应版--> <div id="SOHUCS" sid="1493743753553272832"></div> <script type="text/javascript" src="/views/front/js/chanyan.js"></script> <!-- 文章页-底部 动态广告位 --> <div class="youdao-fixed-ad" id="detail_ad_bottom"></div> </div> <div class="col-md-3"> <div class="row" id="ad"> <!-- 文章页-右侧1 动态广告位 --> <div id="right-1" class="col-lg-12 col-md-12 col-sm-4 col-xs-4 ad"> <div class="youdao-fixed-ad" id="detail_ad_1"> </div> </div> <!-- 文章页-右侧2 动态广告位 --> <div id="right-2" class="col-lg-12 col-md-12 col-sm-4 col-xs-4 ad"> <div class="youdao-fixed-ad" id="detail_ad_2"></div> </div> <!-- 文章页-右侧3 动态广告位 --> <div id="right-3" class="col-lg-12 col-md-12 col-sm-4 col-xs-4 ad"> <div class="youdao-fixed-ad" id="detail_ad_3"></div> </div> </div> </div> </div> </div> </div> <div class="container"> <h4 class="pt20 mb15 mt0 border-top">你可能感兴趣的:(2020秋招前端面经知识点汇总(一) html,css部分)</h4> <div id="paradigm-article-related"> <div class="recommend-post mb30"> <ul class="widget-links"> <li><a href="/article/1881308270820388864.htm" title="数据复制二(多主复制详解)" target="_blank">数据复制二(多主复制详解)</a> <span class="text-muted">风清扬-独孤九剑</span> <a class="tag" taget="_blank" href="/search/mysql/1.htm">mysql</a><a class="tag" taget="_blank" href="/search/%E5%A4%9A%E6%B4%BB/1.htm">多活</a><a class="tag" taget="_blank" href="/search/%E5%A4%9A%E4%B8%BB/1.htm">多主</a><a class="tag" taget="_blank" href="/search/%E5%A4%9A%E6%95%B0%E6%8D%AE%E4%B8%AD%E5%BF%83/1.htm">多数据中心</a> <div>目录一、多主复制二、多主复制常用的场景三、多主复制处理写冲突四、自定义冲突解决一、多主复制在上一篇文章谈到了主从复制,对于一个超大规模应用,主从往往是不够用的。还需要多个数据中心,这些数据中心可能部署的全球的任何一个位置。每个数据中心都是主从配置,数据中心的主节点对于其他数据中心来说就是从节点。一个数据中心数据发生变化,异步同步到其他的数据中心的主节点。为了容忍整个数据中心级别故障或者更接近用户,</div> </li> <li><a href="/article/1881308262775713792.htm" title="数据复制一(主从复制详解)" target="_blank">数据复制一(主从复制详解)</a> <span class="text-muted">风清扬-独孤九剑</span> <a class="tag" taget="_blank" href="/search/mysql/1.htm">mysql</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%A4%8D%E5%88%B6/1.htm">数据复制</a><a class="tag" taget="_blank" href="/search/%E4%B8%BB%E4%BB%8E%E5%A4%8D%E5%88%B6/1.htm">主从复制</a> <div>目录一、主从复制二、同步复制和异步复制三、节点失效处理方案四、复制日志的实现五、复制滞后问题读自己的写单调读前缀一致读数据复制就是相同的数据在多台机器上传输,多台机器可以在一个机房也不可以跨区域。通过数据复制有以下好处:降低访问延迟(数据复制到离用户更近的地方)、当机器出现故障时,可以切换到副本机器,从而提高可用性、多台机器可以同时提供服务,从而提高吞吐量。现在计算机技术来说数据复制就几种方法:主</div> </li> <li><a href="/article/1881307884613070848.htm" title="SimpleHelp远程管理软件 任意文件读取漏洞复现(CVE-2024-57727)(附脚本)" target="_blank">SimpleHelp远程管理软件 任意文件读取漏洞复现(CVE-2024-57727)(附脚本)</a> <span class="text-muted">iSee857</span> <a class="tag" taget="_blank" href="/search/%E6%BC%8F%E6%B4%9E%E5%A4%8D%E7%8E%B0/1.htm">漏洞复现</a><a class="tag" taget="_blank" href="/search/%E5%AE%89%E5%85%A8/1.htm">安全</a><a class="tag" taget="_blank" href="/search/web%E5%AE%89%E5%85%A8/1.htm">web安全</a> <div>免责申明:本文所描述的漏洞及其复现步骤仅供网络安全研究与教育目的使用。任何人不得将本文提供的信息用于非法目的或未经授权的系统测试。作者不对任何由于使用本文信息而导致的直接或间接损害承担责任。0x01产品描述:SimpleHelp是一款远程支持和服务交付软件,它允许技术支持团队通过互联网远程访问和控制客户端计算机,以便进行故障排除、维护和提供技术支持。该软件设计用于简化远程协助过程,提高效率,并减少</div> </li> <li><a href="/article/1881307632204050432.htm" title="Python 实战-优化排班表节省成本" target="_blank">Python 实战-优化排班表节省成本</a> <span class="text-muted">奔向理想的星辰大海</span> <a class="tag" taget="_blank" href="/search/%E6%8A%80%E6%9C%AF%E7%A0%94%E5%8F%91/1.htm">技术研发</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/ios/1.htm">ios</a><a class="tag" taget="_blank" href="/search/objective-c/1.htm">objective-c</a> <div>1.基础概念:理解排班表排班表,顾名思义,就是安排员工工作时间的表格。在餐馆中,它通常需要考虑员工的可用性、工作时间限制、用餐高峰时段等因素。2.使用列表存储员工信息首先,我们需要一个数据结构来存储员工信息。Python中的列表是一个不错的选择。#员工信息列表,包括姓名、可用时间段employees=[{"name":"张三","available":[(9,17),(20,23)]},{"nam</div> </li> <li><a href="/article/1881307128128401408.htm" title="Java并发编程:线程安全的策略与实践" target="_blank">Java并发编程:线程安全的策略与实践</a> <span class="text-muted">喵手</span> <a class="tag" taget="_blank" href="/search/%E9%9B%B6%E5%9F%BA%E7%A1%80%E5%AD%A6Java/1.htm">零基础学Java</a><a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E5%AE%89%E5%85%A8/1.htm">安全</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a> <div>哈喽,各位小伙伴们,你们好呀,我是喵手。运营社区:C站/掘金/腾讯云/阿里云/华为云/51CTO;欢迎大家常来逛逛  今天我要给大家分享一些自己日常学习到的一些知识点,并以文字的形式跟大家一起交流,互相学习,一个人虽可以走的更快,但一群人可以走的更远。  我是一名后端开发爱好者,工作日常接触到最多的就是Java语言啦,所以我都尽量抽业余时间把自己所学到所会的,通过文章的形式进行输出,希望以这种方式</div> </li> <li><a href="/article/1881306622916096000.htm" title="自己动手写CPU - 1" target="_blank">自己动手写CPU - 1</a> <span class="text-muted">qq85058522</span> <a class="tag" taget="_blank" href="/search/%E8%87%AA%E5%B7%B1%E5%8A%A8%E6%89%8B%E5%86%99CPU/1.htm">自己动手写CPU</a><a class="tag" taget="_blank" href="/search/fpga%E5%BC%80%E5%8F%91/1.htm">fpga开发</a> <div>电脑,手机,单片机,都有一个核心部件:CPU.今天开始学verilog,就尝试一下动手写一个可以工作的CPU.目标就是可以计算从1加到10等于几?分析一下,大概需要几个指令:LdrAddSubCmpJmp第一步,先写一个运算部件:ALU.modulealu0(input[3:0]op,input[7:0]in1,in2,outputreg[7:0]out1);always@(*)begincase</div> </li> <li><a href="/article/1881306496512356352.htm" title="自己动手写CPU - 6" target="_blank">自己动手写CPU - 6</a> <span class="text-muted">qq85058522</span> <a class="tag" taget="_blank" href="/search/%E8%87%AA%E5%B7%B1%E5%8A%A8%E6%89%8B%E5%86%99CPU/1.htm">自己动手写CPU</a><a class="tag" taget="_blank" href="/search/fpga%E5%BC%80%E5%8F%91/1.htm">fpga开发</a> <div>自己动手写CPU_qq85058522的博客-CSDN博客CPU不加功能了,但汇编器可以有。下面写一个把汇编(助记符)翻译成机器码的小工具。Python熟些,就用它了。很简单,就是字符串替换。直接上代码。importsysiflen(sys.argv)!=2:print("usage:pythonassemblerxxx.asm")exit(0)code_path=sys.argv[1]print</div> </li> <li><a href="/article/1881306369835986944.htm" title="ros2_control 6 自由度机械臂" target="_blank">ros2_control 6 自由度机械臂</a> <span class="text-muted">kuan_li_lyg</span> <a class="tag" taget="_blank" href="/search/ROS/1.htm">ROS</a><a class="tag" taget="_blank" href="/search/%26amp%3B/1.htm">&</a><a class="tag" taget="_blank" href="/search/ROS2/1.htm">ROS2</a><a class="tag" taget="_blank" href="/search/%E6%9C%BA%E5%99%A8%E4%BA%BA/1.htm">机器人</a><a class="tag" taget="_blank" href="/search/%E4%BA%BA%E5%B7%A5%E6%99%BA%E8%83%BD/1.htm">人工智能</a><a class="tag" taget="_blank" href="/search/ROS/1.htm">ROS</a><a class="tag" taget="_blank" href="/search/%E6%9C%BA%E6%A2%B0%E8%87%82/1.htm">机械臂</a><a class="tag" taget="_blank" href="/search/%E6%8E%A7%E5%88%B6%E5%B7%A5%E7%A8%8B/1.htm">控制工程</a><a class="tag" taget="_blank" href="/search/%E7%AE%97%E6%B3%95/1.htm">算法</a> <div>系列文章目录前言ros2_control是一个实时控制框架,专为普通机器人应用而设计。标准的c++接口用于与硬件交互和查询用户定义的控制器命令。这些接口增强了代码的模块化和与机器人无关的设计。具体的应用细节,例如使用什么控制器、机器人有多少个关节以及它们的运动学结构,则通过YAML参数配置文件和通用机器人描述文件(URDF)来指定。最后,通过ROS2启动文件部署ros2_control框架。本教程</div> </li> <li><a href="/article/1881305740094795776.htm" title="Dufs开源Web文件服务器" target="_blank">Dufs开源Web文件服务器</a> <span class="text-muted">爱辉弟啦</span> <a class="tag" taget="_blank" href="/search/linux%E8%BF%90%E7%BB%B4/1.htm">linux运维</a><a class="tag" taget="_blank" href="/search/linux/1.htm">linux</a><a class="tag" taget="_blank" href="/search/%E8%BF%90%E7%BB%B4/1.htm">运维</a><a class="tag" taget="_blank" href="/search/%E6%9C%8D%E5%8A%A1%E5%99%A8/1.htm">服务器</a><a class="tag" taget="_blank" href="/search/Web%E6%96%87%E4%BB%B6%E6%9C%8D%E5%8A%A1%E5%99%A8/1.htm">Web文件服务器</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E6%BA%90%E8%BD%AF%E4%BB%B6/1.htm">开源软件</a> <div>介绍:Dufs是一个独特的实用文件服务器,支持静态服务,上传,搜索,访问控制,webdav…GitHub-sigoden/dufs:Afileserverthatsupportsstaticserving,uploading,searching,accessingcontrol,webdav…功能列表提供静态文件下载文件夹为zip文件上传文件和文件夹(拖放)创建/编辑/搜索文件可恢复的部分上传/下</div> </li> <li><a href="/article/1881305613758164992.htm" title="C++ 多态 初学笔记" target="_blank">C++ 多态 初学笔记</a> <span class="text-muted">NicOym</span> <a class="tag" taget="_blank" href="/search/C%2B%2B/1.htm">C++</a><a class="tag" taget="_blank" href="/search/c%2B%2B/1.htm">c++</a> <div>多态虚函数虚函数的使用条件虚函数详解对象多态多重继承时,类型转换的练习(1)情况1:(2)情况2:(3)情况3:(4)情况4:对象多态动态强制转换dynamic_casttypeid抽象类类的成员函数的函数指针概念:允许使用统一的接口来操作不同类型的对象。多态的作用:减少重复代码,提高代码扩展性静态多态:函数重载函数模板动态多态继承虚函数虚函数:动态绑定静态绑定个人记法(可能有误):动态绑定是调用</div> </li> <li><a href="/article/1881305487434117120.htm" title="同城双活和两地三中心架构设计" target="_blank">同城双活和两地三中心架构设计</a> <span class="text-muted">架构未来</span> <a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%BA%93/1.htm">数据库</a><a class="tag" taget="_blank" href="/search/%E7%BD%91%E7%BB%9C/1.htm">网络</a><a class="tag" taget="_blank" href="/search/%E6%9E%B6%E6%9E%84/1.htm">架构</a> <div>一、同城双活同城双活是在同城或相近区域内建立两个机房。同城双机房距离比较近,通信线路质量较好,比较容易实现数据的同步复制,保证高度的数据完整性和数据零丢失。同城两个机房各承担一部分流量,一般入口流量完全随机,内部RPC调用尽量通过就近路由闭环在同机房,相当于两个机房镜像部署了两个独立集群,数据仍然是单点写到主机房数据库,然后实时同步到另外一个机房。下图展示了同城双活简单部署架构:服务调用基本在同机</div> </li> <li><a href="/article/1881305360959074304.htm" title="mysql gtid 主从_基于GTID搭建主从MySQL" target="_blank">mysql gtid 主从_基于GTID搭建主从MySQL</a> <span class="text-muted">呓人61</span> <a class="tag" taget="_blank" href="/search/mysql/1.htm">mysql</a><a class="tag" taget="_blank" href="/search/gtid/1.htm">gtid</a><a class="tag" taget="_blank" href="/search/%E4%B8%BB%E4%BB%8E/1.htm">主从</a> <div>基于gtid搭建主从MySQL一、GTID的使用想让主从之间使用gtid的方式同步数据,需要我们在配置文件中开启mysql对gtid相关的配置信息找到my.cnf,在mysqld模块中加入如下的配置。(主库从库都这样)#on表示开启,OFF表示关闭gtid-mode=ON#下面的两个变量必须开启,否则MySQL拒绝启动#通常情况,从服务器从主服务器接收到的更新不记入它的二进制日志。该选项告诉从服务</div> </li> <li><a href="/article/1881304855620939776.htm" title="python多进程编程_深入理解python多进程编程" target="_blank">python多进程编程_深入理解python多进程编程</a> <span class="text-muted">weixin_39620001</span> <a class="tag" taget="_blank" href="/search/python%E5%A4%9A%E8%BF%9B%E7%A8%8B%E7%BC%96%E7%A8%8B/1.htm">python多进程编程</a> <div>1、python多进程编程背景python中的多进程最大的好处就是充分利用多核cpu的资源,不像python中的多线程,受制于GIL的限制,从而只能进行cpu分配,在python的多进程中,适合于所有的场合,基本上能用多线程的,那么基本上就能用多进程。在进行多进程编程的时候,其实和多线程差不多,在多线程的包threading中,存在一个线程类Thread,在其中有三种方法来创建一个线程,启动线程,</div> </li> <li><a href="/article/1881304856182976512.htm" title="python多进程编程实例_Python多进程编程multiprocessing代码实例" target="_blank">python多进程编程实例_Python多进程编程multiprocessing代码实例</a> <span class="text-muted">weixin_39791386</span> <a class="tag" taget="_blank" href="/search/python%E5%A4%9A%E8%BF%9B%E7%A8%8B%E7%BC%96%E7%A8%8B%E5%AE%9E%E4%BE%8B/1.htm">python多进程编程实例</a> <div>在多线程与多进程的比较这一篇中记录了多进程编程的一种方式.下面记录一下多进程编程的别一种方式,即使用multiprocessing编程importmultiprocessingimporttimedefget_html(n):time.sleep(n)print('subprocess%s'%n)returnnif__name__=='__main__':#多进程编程process=multipr</div> </li> <li><a href="/article/1881304729263337472.htm" title="python打开一个软件并进行操作_模拟试卷 B" target="_blank">python打开一个软件并进行操作_模拟试卷 B</a> <span class="text-muted">weixin_39551611</span> <div>原标题:模拟试卷B一、单项选择题1.关于算法的描述,以下选项中错误的是算法是指解题方案的准确而完整的描述算法具有可行性、确定性、有穷性的基本特征算法的复杂度主要包括时间复杂度和数据复杂度算法的基本要素包括数据对象的运算和操作及算法的控制结构2.关于数据结构的描述,以下选项中正确的是数据结构指相互有关联的数据元素的集合数据的存储结构是指反映数据元素之间逻辑关系的数据结构数据的逻辑结构有顺序、链接、索</div> </li> <li><a href="/article/1881304602842820608.htm" title="pnpm简介" target="_blank">pnpm简介</a> <span class="text-muted">渔老师</span> <a class="tag" taget="_blank" href="/search/npm/1.htm">npm</a><a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF/1.htm">前端</a><a class="tag" taget="_blank" href="/search/javascript/1.htm">javascript</a> <div>pnpm简介pnpm是什么和npm,yarn一样,pnpm是一个包管理工具。不一样的是,pnpm解决了npm和yarn一直都没有解决的痛点。在许多方面比npm和yarn更优秀。pnpm对比npm/yarn的优点更快速的依赖下载更高效的利用磁盘空间更优秀的依赖管理更快速的依赖下载根据官方提供的数据从图上我们可以看出,pnpm平均比npm和yarn快上2~3倍。这一点在依赖的下载上额外明显。更高效的利</div> </li> <li><a href="/article/1881304476342611968.htm" title="【Elasticsearch 实战应用】" target="_blank">【Elasticsearch 实战应用】</a> <span class="text-muted">wenshao.du</span> <a class="tag" taget="_blank" href="/search/elasticsearch/1.htm">elasticsearch</a> <div>Elasticsearch实战应用在现代企业技术架构中,Elasticsearch因其出色的性能、可扩展性和易用性,成为了处理大规模数据和构建搜索引擎的首选工具。本文将通过一个实际案例,详细讲解如何在SpringBoot项目中集成Elasticsearch,进行数据索引、搜索、聚合分析等操作。1.Elasticsearch简介Elasticsearch是一个基于ApacheLucene构建的开源分</div> </li> <li><a href="/article/1881304474748776448.htm" title="python之openpyxl模块" target="_blank">python之openpyxl模块</a> <span class="text-muted">weixin_34248849</span> <a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E7%BB%93%E6%9E%84%E4%B8%8E%E7%AE%97%E6%B3%95/1.htm">数据结构与算法</a><a class="tag" taget="_blank" href="/search/%E6%B5%8B%E8%AF%95/1.htm">测试</a> <div>一.Python操作EXCEL库的简介1.1Python官方库操作excelPython官方库一般使用xlrd库来读取Excel文件,使用xlwt库来生成Excel文件,使用xlutils库复制和修改Excel文件,这三个库只支持到Excel2003。1.2第三方库openpyxl介绍第三方库openpyxl(可读写excel表),专门处理Excel2007及以上版本产生的xlsx文件,xls和x</div> </li> <li><a href="/article/1881304348466671616.htm" title="mysql开启gtid主从切换_Mysql 基于GTID的主从复制及切换" target="_blank">mysql开启gtid主从切换_Mysql 基于GTID的主从复制及切换</a> <span class="text-muted">蕲艾唉啊</span> <a class="tag" taget="_blank" href="/search/mysql%E5%BC%80%E5%90%AFgtid%E4%B8%BB%E4%BB%8E%E5%88%87%E6%8D%A2/1.htm">mysql开启gtid主从切换</a> <div>参考http://imysql.com/tag/gtidhttp://mysqllover.com/?p=594Mysql基于GTID的主从复制及切换一、主从复制配置两个mysql服务的my.cnf中相关内容配置[mysqld]#从复制数据库表设置replicate-wild-ignore-table=mysql.%,information_schema.%,innodb.%,innodb_log</div> </li> <li><a href="/article/1881303088720048128.htm" title="深入解析:Postgres 和 MySQL 的核心差异与选择建议" target="_blank">深入解析:Postgres 和 MySQL 的核心差异与选择建议</a> <span class="text-muted">zhu hong yu</span> <a class="tag" taget="_blank" href="/search/mysql/1.htm">mysql</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%BA%93/1.htm">数据库</a><a class="tag" taget="_blank" href="/search/postgresql/1.htm">postgresql</a> <div>几十年来,关系数据库为无数应用程序提供了支持,它们仍然是许多现代系统的支柱。说到可用于生产的选项,有两种最为广泛使用的数据库,即PostgreSQL和MySQL。两者都提供了可靠的性能、可靠性和社区支持,但它们在处理数据的方式、功能集和配置难易程度方面存在明显差异。了解这些细微差别可以帮助您根据特定需求选择合适的数据库。何时应该使用PostgreSQL或MySQL?下表概括了一些最大的差异:标准P</div> </li> <li><a href="/article/1881301953858826240.htm" title="SOA 术语概述,第 2 部分: 开发流程、模型和资产" target="_blank">SOA 术语概述,第 2 部分: 开发流程、模型和资产</a> <span class="text-muted">rochening</span> <a class="tag" taget="_blank" href="/search/soa/1.htm">soa</a><a class="tag" taget="_blank" href="/search/uml/1.htm">uml</a><a class="tag" taget="_blank" href="/search/ibm/1.htm">ibm</a><a class="tag" taget="_blank" href="/search/eclipse/1.htm">eclipse</a><a class="tag" taget="_blank" href="/search/%E5%B7%A5%E4%BD%9C/1.htm">工作</a><a class="tag" taget="_blank" href="/search/%E5%B9%B3%E5%8F%B0/1.htm">平台</a> <div>文档选项将此页作为电子邮件发送拓展Tomcat应用下载IBM开源J2EE应用服务器WASCE新版本V1.1级别:初级BertrandPortier(bportier@ca.ibm.com),IT架构师,IBM,Intel,Microsoft,HP2007年5月23日了解一些基本SOA术语。本文是本系列的第2部分,BertrandPortier将在其中定义一些术语(包括开发流程、模型和资产)并说明为</div> </li> <li><a href="/article/1881301575494856704.htm" title="MySQL基于gtid主从复制(一主一从、一主多从、双主一从)" target="_blank">MySQL基于gtid主从复制(一主一从、一主多从、双主一从)</a> <span class="text-muted">晶核高手</span> <a class="tag" taget="_blank" href="/search/mysql/1.htm">mysql</a><a class="tag" taget="_blank" href="/search/mysql/1.htm">mysql</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%BA%93/1.htm">数据库</a> <div>MySQL基于gtid主从复制(一主一从、一主多从、双主一从)MySQL基于gtid主从复制什么是GTID?全局唯一,一个事务对应一个GTID替代传统的binlog+pos复制;使用master_auto_position=1自动匹配GTID断点进行复制MySQL5.6开始支持在传统的主从复制中,slave端不用开启binlog;但是在GTID主从复制中,必须开启binlogslave端在接受ma</div> </li> <li><a href="/article/1881300566500503552.htm" title="Nginx 配置文件基础语法解析" target="_blank">Nginx 配置文件基础语法解析</a> <span class="text-muted">计算机毕设定制辅导-无忧学长</span> <a class="tag" taget="_blank" href="/search/%23/1.htm">#</a><a class="tag" taget="_blank" href="/search/Nginx/1.htm">Nginx</a><a class="tag" taget="_blank" href="/search/nginx/1.htm">nginx</a><a class="tag" taget="_blank" href="/search/github/1.htm">github</a><a class="tag" taget="_blank" href="/search/%E8%BF%90%E7%BB%B4/1.htm">运维</a> <div>一、Nginx简介在当今的Web服务领域,Nginx无疑是一款备受瞩目的明星产品。它是由IgorSysoev开发的一款高性能的HTTP和反向代理服务器,同时也具备IMAP/POP3/SMTP代理服务功能。自2004年首次发布以来,凭借其卓越的性能、出色的稳定性和极高的灵活性,迅速在Web服务器市场中崭露头角。Nginx的高性能体现在多个方面。其采用了事件驱动和异步非阻塞的架构设计,使得它能够高效地</div> </li> <li><a href="/article/1881300439362760704.htm" title="《中型 Vue 项目:挑战与成长》" target="_blank">《中型 Vue 项目:挑战与成长》</a> <span class="text-muted">计算机毕设定制辅导-无忧学长</span> <a class="tag" taget="_blank" href="/search/%23/1.htm">#</a><a class="tag" taget="_blank" href="/search/Vue/1.htm">Vue</a><a class="tag" taget="_blank" href="/search/vue.js/1.htm">vue.js</a><a class="tag" taget="_blank" href="/search/flutter/1.htm">flutter</a><a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF/1.htm">前端</a> <div>一、引言在当今的前端开发领域,Vue作为一款渐进式JavaScript框架,以其强大的功能和灵活性备受开发者青睐。对于中型Vue项目而言,其重要性不言而喻。中型Vue项目通常在功能复杂度和规模上介于小型项目和大型项目之间,既需要应对一定的业务需求挑战,又要考虑开发效率和可维护性。中型Vue项目面临着诸多挑战与机遇。挑战方面,随着项目规模的扩大,代码的复杂性增加,如何进行有效的状态管理、组件化开发以</div> </li> <li><a href="/article/1881300440121929728.htm" title="大型系统中 HTTP 的优化与部署" target="_blank">大型系统中 HTTP 的优化与部署</a> <span class="text-muted">计算机毕设定制辅导-无忧学长</span> <a class="tag" taget="_blank" href="/search/%23/1.htm">#</a><a class="tag" taget="_blank" href="/search/HTTP/1.htm">HTTP</a><a class="tag" taget="_blank" href="/search/http/1.htm">http</a><a class="tag" taget="_blank" href="/search/%E7%BD%91%E7%BB%9C%E5%8D%8F%E8%AE%AE/1.htm">网络协议</a><a class="tag" taget="_blank" href="/search/%E7%BD%91%E7%BB%9C/1.htm">网络</a> <div>一、引言在当今数字化时代,大型系统的构建与运行离不开高效的网络通信。HTTP,作为超文本传输协议,在大型系统中扮演着举足轻重的角色,负责客户端与服务器之间的信息传输,是实现各类网络应用的基础。无论是电商平台的商品展示与交易、社交网络的动态分享与互动,还是在线办公系统的文件传输与协作,都依赖HTTP协议来确保数据的准确、快速传递。随着业务的不断拓展和用户量的急剧增长,大型系统面临着高并发请求、海量数</div> </li> <li><a href="/article/1881300312908689408.htm" title="中型项目中 MyBatis 的挑战与应对" target="_blank">中型项目中 MyBatis 的挑战与应对</a> <span class="text-muted">计算机毕设定制辅导-无忧学长</span> <a class="tag" taget="_blank" href="/search/%23/1.htm">#</a><a class="tag" taget="_blank" href="/search/MyBatis/1.htm">MyBatis</a><a class="tag" taget="_blank" href="/search/mybatis/1.htm">mybatis</a> <div>一、引言在当今的Java企业级开发领域,MyBatis无疑是一款占据重要地位的持久层框架。它像是一座桥梁,优雅地连接着Java应用程序与数据库,让数据的交互变得高效且便捷。当我们聚焦于中型项目时,随着业务复杂度的提升以及数据量的增长,MyBatis在为我们带来便利的同时,也悄然面临着诸多挑战。这些挑战涵盖了从性能瓶颈到代码维护性,从数据库兼容性到事务管理等多个关键层面。深入探究这些问题并找寻有效的</div> </li> <li><a href="/article/1881300310098505728.htm" title="中型项目下的 MySQL 挑战与应对" target="_blank">中型项目下的 MySQL 挑战与应对</a> <span class="text-muted">计算机毕设定制辅导-无忧学长</span> <a class="tag" taget="_blank" href="/search/%23/1.htm">#</a><a class="tag" taget="_blank" href="/search/MySQL/1.htm">MySQL</a><a class="tag" taget="_blank" href="/search/mysql/1.htm">mysql</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%BA%93/1.htm">数据库</a> <div>中型项目里MySQL面临的挑战数据量增长挑战在中型项目的发展进程中,业务不断拓展,数据量往往会呈现出持续增长的态势,这就给MySQL带来了不小的挑战。要知道,MySQL单表虽然理论上可以存储10亿级的数据,但当数据量达到亿级时,其性能,比如查询速度等方面,就会面临严峻的考验,处理效率会大打折扣,进而影响整个系统的运行效率。例如,在某些项目实例(一主一从)中,曾出现过告警情况,每天凌晨会报SLA报警</div> </li> <li><a href="/article/1881299679925301248.htm" title="上海计算机学会2020年10月月赛C++丙组T5小球的颜色" target="_blank">上海计算机学会2020年10月月赛C++丙组T5小球的颜色</a> <span class="text-muted">长春高老师编程</span> <a class="tag" taget="_blank" href="/search/%E4%B8%8A%E6%B5%B7%E8%AE%A1%E7%AE%97%E6%9C%BA%E5%AD%A6%E4%BC%9A%E6%9C%88%E8%B5%9B%E4%B8%99%E7%BB%84/1.htm">上海计算机学会月赛丙组</a><a class="tag" taget="_blank" href="/search/c%2B%2B/1.htm">c++</a><a class="tag" taget="_blank" href="/search/%E7%AE%97%E6%B3%95/1.htm">算法</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a> <div>小球的颜色内存限制:256Mb时间限制:1000ms题目描述给定n个数字a1,a2,…,an。我们需要更改一些数字,使得最后数字种类不超过k种,请问最少需要更改多少数字。输入格式第一行:两个整数n与k;第二行:n个整数a1,a2,…,an。输出格式单个整数,表示答案。数据范围对于30%的数据,1≤n≤100;对于40%的数据,1≤n≤1000;对于100%的数据,1≤k≤n≤2×10^5。1≤ai</div> </li> <li><a href="/article/1881299427663081472.htm" title="npm介绍" target="_blank">npm介绍</a> <span class="text-muted">小玉起起</span> <a class="tag" taget="_blank" href="/search/vue/1.htm">vue</a><a class="tag" taget="_blank" href="/search/js/1.htm">js</a><a class="tag" taget="_blank" href="/search/npm/1.htm">npm</a><a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF/1.htm">前端</a><a class="tag" taget="_blank" href="/search/node.js/1.htm">node.js</a> <div>npm(NodePackageManager)是Node.js的默认包管理工具,用于管理JavaScript和Node.js项目的依赖关系。它既是一个包管理工具,又是一个在线仓库,开发者可以通过它分享和下载开源的JavaScript库和工具。npm是世界上最大的开源软件注册表,托管着超过一百万个包。主要功能和特点1.包管理npm的核心功能是管理依赖包。它允许开发者方便地安装、更新和删除项目中的依赖</div> </li> <li><a href="/article/1881299423426834432.htm" title="kafka 学习笔记3-传统部署Kraft模式集群——筑梦之路" target="_blank">kafka 学习笔记3-传统部署Kraft模式集群——筑梦之路</a> <span class="text-muted">筑梦之路</span> <a class="tag" taget="_blank" href="/search/kafka/1.htm">kafka</a><a class="tag" taget="_blank" href="/search/%E5%AD%A6%E4%B9%A0/1.htm">学习</a><a class="tag" taget="_blank" href="/search/%E7%AC%94%E8%AE%B0/1.htm">笔记</a> <div>部署kafka集群规划一般模式下,元数据在zookeeper中,运行时动态选举controller,由controller进行Kafka集群管理。kraft模式架构下,不再依赖zookeeper集群,而是用三台controller节点代替zookeeper,元数据保存在controller中,由controller直接进行Kafka集群管理。ip主机名角色nodeid192.168.100.131</div> </li> <li><a href="/article/36.htm" title="ASM系列四 利用Method 组件动态注入方法逻辑" target="_blank">ASM系列四 利用Method 组件动态注入方法逻辑</a> <span class="text-muted">lijingyao8206</span> <a class="tag" taget="_blank" href="/search/%E5%AD%97%E8%8A%82%E7%A0%81%E6%8A%80%E6%9C%AF/1.htm">字节码技术</a><a class="tag" taget="_blank" href="/search/jvm/1.htm">jvm</a><a class="tag" taget="_blank" href="/search/AOP/1.htm">AOP</a><a class="tag" taget="_blank" href="/search/%E5%8A%A8%E6%80%81%E4%BB%A3%E7%90%86/1.htm">动态代理</a><a class="tag" taget="_blank" href="/search/ASM/1.htm">ASM</a> <div>        这篇继续结合例子来深入了解下Method组件动态变更方法字节码的实现。通过前面一篇,知道ClassVisitor 的visitMethod()方法可以返回一个MethodVisitor的实例。那么我们也基本可以知道,同ClassVisitor改变类成员一样,MethodVIsistor如果需要改变方法成员,注入逻辑,也可以</div> </li> <li><a href="/article/163.htm" title="java编程思想 --内部类" target="_blank">java编程思想 --内部类</a> <span class="text-muted">百合不是茶</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E5%86%85%E9%83%A8%E7%B1%BB/1.htm">内部类</a><a class="tag" taget="_blank" href="/search/%E5%8C%BF%E5%90%8D%E5%86%85%E9%83%A8%E7%B1%BB/1.htm">匿名内部类</a> <div>内部类;了解外部类 并能与之通信 内部类写出来的代码更加整洁与优雅   1,内部类的创建  内部类是创建在类中的 package com.wj.InsideClass; /* * 内部类的创建 */ public class CreateInsideClass { public CreateInsideClass(</div> </li> <li><a href="/article/290.htm" title="web.xml报错" target="_blank">web.xml报错</a> <span class="text-muted">crabdave</span> <a class="tag" taget="_blank" href="/search/web.xml/1.htm">web.xml</a> <div>web.xml报错   The content of element type "web-app" must match "(icon?,display-  name?,description?,distributable?,context-param*,filter*,filter-mapping*,listener*,servlet*,s</div> </li> <li><a href="/article/417.htm" title="泛型类的自定义" target="_blank">泛型类的自定义</a> <span class="text-muted">麦田的设计者</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/android/1.htm">android</a><a class="tag" taget="_blank" href="/search/%E6%B3%9B%E5%9E%8B/1.htm">泛型</a> <div>   为什么要定义泛型类,当类中要操作的引用数据类型不确定的时候。 采用泛型类,完成扩展。   例如有一个学生类     Student{ Student(){ System.out.println("I'm a student....."); } }  有一个老师类   </div> </li> <li><a href="/article/544.htm" title="CSS清除浮动的4中方法" target="_blank">CSS清除浮动的4中方法</a> <span class="text-muted">IT独行者</span> <a class="tag" taget="_blank" href="/search/JavaScript/1.htm">JavaScript</a><a class="tag" taget="_blank" href="/search/UI/1.htm">UI</a><a class="tag" taget="_blank" href="/search/css/1.htm">css</a> <div>清除浮动这个问题,做前端的应该再熟悉不过了,咱是个新人,所以还是记个笔记,做个积累,努力学习向大神靠近。CSS清除浮动的方法网上一搜,大概有N多种,用过几种,说下个人感受。 1、结尾处加空div标签 clear:both 1 2 3 4 .div 1 { background : #000080 ; border : 1px   s</div> </li> <li><a href="/article/671.htm" title="Cygwin使用windows的jdk 配置方法" target="_blank">Cygwin使用windows的jdk 配置方法</a> <span class="text-muted">_wy_</span> <a class="tag" taget="_blank" href="/search/jdk/1.htm">jdk</a><a class="tag" taget="_blank" href="/search/windows/1.htm">windows</a><a class="tag" taget="_blank" href="/search/cygwin/1.htm">cygwin</a> <div>1.[vim /etc/profile]    JAVA_HOME="/cgydrive/d/Java/jdk1.6.0_43"  (windows下jdk路径为D:\Java\jdk1.6.0_43)    PATH="$JAVA_HOME/bin:${PATH}"    CLAS</div> </li> <li><a href="/article/798.htm" title="linux下安装maven" target="_blank">linux下安装maven</a> <span class="text-muted">无量</span> <a class="tag" taget="_blank" href="/search/maven/1.htm">maven</a><a class="tag" taget="_blank" href="/search/linux/1.htm">linux</a><a class="tag" taget="_blank" href="/search/%E5%AE%89%E8%A3%85/1.htm">安装</a> <div>Linux下安装maven(转) 1.首先到Maven官网 下载安装文件,目前最新版本为3.0.3,下载文件为 apache-maven-3.0.3-bin.tar.gz,下载可以使用wget命令; 2.进入下载文件夹,找到下载的文件,运行如下命令解压 tar -xvf  apache-maven-2.2.1-bin.tar.gz 解压后的文件夹</div> </li> <li><a href="/article/925.htm" title="tomcat的https 配置,syslog-ng配置" target="_blank">tomcat的https 配置,syslog-ng配置</a> <span class="text-muted">aichenglong</span> <a class="tag" taget="_blank" href="/search/tomcat/1.htm">tomcat</a><a class="tag" taget="_blank" href="/search/http%E8%B7%B3%E8%BD%AC%E5%88%B0https/1.htm">http跳转到https</a><a class="tag" taget="_blank" href="/search/syslong-ng%E9%85%8D%E7%BD%AE/1.htm">syslong-ng配置</a><a class="tag" taget="_blank" href="/search/syslog%E9%85%8D%E7%BD%AE/1.htm">syslog配置</a> <div>1) tomcat配置https,以及http自动跳转到https的配置     1)TOMCAT_HOME目录下生成密钥(keytool是jdk中的命令)      keytool -genkey -alias tomcat -keyalg RSA -keypass changeit -storepass changeit</div> </li> <li><a href="/article/1052.htm" title="关于领号活动总结" target="_blank">关于领号活动总结</a> <span class="text-muted">alafqq</span> <a class="tag" taget="_blank" href="/search/%E6%B4%BB%E5%8A%A8/1.htm">活动</a> <div>关于某彩票活动的总结 具体需求,每个用户进活动页面,领取一个号码,1000中的一个; 活动要求 1,随机性,一定要有随机性; 2,最少中奖概率,如果注数为3200注,则最多中4注 3,效率问题,(不能每个人来都产生一个随机数,这样效率不高); 4,支持断电(仍然从下一个开始),重启服务;(存数据库有点大材小用,因此不能存放在数据库) 解决方案 1,事先产生随机数1000个,并打</div> </li> <li><a href="/article/1179.htm" title="java数据结构 冒泡排序的遍历与排序" target="_blank">java数据结构 冒泡排序的遍历与排序</a> <span class="text-muted">百合不是茶</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a> <div>java的冒泡排序是一种简单的排序规则   冒泡排序的原理:           比较两个相邻的数,首先将最大的排在第一个,第二次比较第二个 ,此后一样;         针对所有的元素重复以上的步骤,除了最后一个     例题;将int array[] </div> </li> <li><a href="/article/1306.htm" title="JS检查输入框输入的是否是数字的一种校验方法" target="_blank">JS检查输入框输入的是否是数字的一种校验方法</a> <span class="text-muted">bijian1013</span> <a class="tag" taget="_blank" href="/search/js/1.htm">js</a> <div>如下是JS检查输入框输入的是否是数字的一种校验方法: <form method=post target="_blank"> 数字:<input type="text" name=num onkeypress="checkNum(this.form)"><br> </form> </div> </li> <li><a href="/article/1433.htm" title="Test注解的两个属性:expected和timeout" target="_blank">Test注解的两个属性:expected和timeout</a> <span class="text-muted">bijian1013</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/JUnit/1.htm">JUnit</a><a class="tag" taget="_blank" href="/search/expected/1.htm">expected</a><a class="tag" taget="_blank" href="/search/timeout/1.htm">timeout</a> <div>JUnit4:Test文档中的解释:   The Test annotation supports two optional parameters.   The first, expected, declares that a test method should throw an exception.   If it doesn't throw an exception or if it </div> </li> <li><a href="/article/1560.htm" title="[Gson二]继承关系的POJO的反序列化" target="_blank">[Gson二]继承关系的POJO的反序列化</a> <span class="text-muted">bit1129</span> <a class="tag" taget="_blank" href="/search/POJO/1.htm">POJO</a> <div>父类     package inheritance.test2; import java.util.Map; public class Model { private String field1; private String field2; private Map<String, String> infoMap</div> </li> <li><a href="/article/1687.htm" title="【Spark八十四】Spark零碎知识点记录" target="_blank">【Spark八十四】Spark零碎知识点记录</a> <span class="text-muted">bit1129</span> <a class="tag" taget="_blank" href="/search/spark/1.htm">spark</a> <div>1. ShuffleMapTask的shuffle数据在什么地方记录到MapOutputTracker中的 ShuffleMapTask的runTask方法负责写数据到shuffle map文件中。当任务执行完成成功,DAGScheduler会收到通知,在DAGScheduler的handleTaskCompletion方法中完成记录到MapOutputTracker中   </div> </li> <li><a href="/article/1814.htm" title="WAS各种脚本作用大全" target="_blank">WAS各种脚本作用大全</a> <span class="text-muted">ronin47</span> <a class="tag" taget="_blank" href="/search/WAS+%E8%84%9A%E6%9C%AC/1.htm">WAS 脚本</a> <div>   http://www.ibm.com/developerworks/cn/websphere/library/samples/SampleScripts.html    无意中,在WAS官网上发现的各种脚本作用,感觉很有作用,先与各位分享一下     获取下载 这些示例 jacl 和 Jython 脚本可用于在 WebSphere Application Server 的不同版本中自</div> </li> <li><a href="/article/1941.htm" title="java-12.求 1+2+3+..n不能使用乘除法、 for 、 while 、 if 、 else 、 switch 、 case 等关键字以及条件判断语句" target="_blank">java-12.求 1+2+3+..n不能使用乘除法、 for 、 while 、 if 、 else 、 switch 、 case 等关键字以及条件判断语句</a> <span class="text-muted">bylijinnan</span> <a class="tag" taget="_blank" href="/search/switch/1.htm">switch</a> <div>借鉴网上的思路,用java实现: public class NoIfWhile { /** * @param args * * find x=1+2+3+....n */ public static void main(String[] args) { int n=10; int re=find(n); System.o</div> </li> <li><a href="/article/2068.htm" title="Netty源码学习-ObjectEncoder和ObjectDecoder" target="_blank">Netty源码学习-ObjectEncoder和ObjectDecoder</a> <span class="text-muted">bylijinnan</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/netty/1.htm">netty</a> <div>Netty中传递对象的思路很直观: Netty中数据的传递是基于ChannelBuffer(也就是byte[]); 那把对象序列化为字节流,就可以在Netty中传递对象了 相应的从ChannelBuffer恢复对象,就是反序列化的过程 Netty已经封装好ObjectEncoder和ObjectDecoder 先看ObjectEncoder ObjectEncoder是往外发送</div> </li> <li><a href="/article/2195.htm" title="spring 定时任务中cronExpression表达式含义" target="_blank">spring 定时任务中cronExpression表达式含义</a> <span class="text-muted">chicony</span> <a class="tag" taget="_blank" href="/search/cronExpression/1.htm">cronExpression</a> <div>一个cron表达式有6个必选的元素和一个可选的元素,各个元素之间是以空格分隔的,从左至右,这些元素的含义如下表所示: 代表含义            是否必须 允许的取值范围         &nb</div> </li> <li><a href="/article/2322.htm" title="Nutz配置Jndi" target="_blank">Nutz配置Jndi</a> <span class="text-muted">ctrain</span> <a class="tag" taget="_blank" href="/search/JNDI/1.htm">JNDI</a> <div>1、使用JNDI获取指定资源: var ioc = { dao : { type :"org.nutz.dao.impl.NutDao", args : [ {jndi :"jdbc/dataSource"} ] } } 以上方法,仅需要在容器中配置好数据源,注入到NutDao即可. </div> </li> <li><a href="/article/2449.htm" title="解决 /bin/sh^M: bad interpreter: No such file or directory" target="_blank">解决 /bin/sh^M: bad interpreter: No such file or directory</a> <span class="text-muted">daizj</span> <a class="tag" taget="_blank" href="/search/shell/1.htm">shell</a> <div>在Linux中执行.sh脚本,异常/bin/sh^M: bad interpreter: No such file or directory。   分析:这是不同系统编码格式引起的:在windows系统中编辑的.sh文件可能有不可见字符,所以在Linux系统下执行会报以上异常信息。 解决: 1)在windows下转换: 利用一些编辑器如UltraEdit或EditPlus等工具</div> </li> <li><a href="/article/2576.htm" title="[转]for 循环为何可恨?" target="_blank">[转]for 循环为何可恨?</a> <span class="text-muted">dcj3sjt126com</span> <a class="tag" taget="_blank" href="/search/%E7%A8%8B%E5%BA%8F%E5%91%98/1.htm">程序员</a><a class="tag" taget="_blank" href="/search/%E8%AF%BB%E4%B9%A6/1.htm">读书</a> <div>  Java的闭包(Closure)特征最近成为了一个热门话题。 一些精英正在起草一份议案,要在Java将来的版本中加入闭包特征。 然而,提议中的闭包语法以及语言上的这种扩充受到了众多Java程序员的猛烈抨击。 不久前,出版过数十本编程书籍的大作家Elliotte Rusty Harold发表了对Java中闭包的价值的质疑。 尤其是他问道“for 循环为何可恨?”[http://ju</div> </li> <li><a href="/article/2703.htm" title="Android实用小技巧" target="_blank">Android实用小技巧</a> <span class="text-muted">dcj3sjt126com</span> <a class="tag" taget="_blank" href="/search/android/1.htm">android</a> <div>1、去掉所有Activity界面的标题栏   修改AndroidManifest.xml   在application 标签中添加android:theme="@android:style/Theme.NoTitleBar"   2、去掉所有Activity界面的TitleBar 和StatusBar    修改AndroidManifes</div> </li> <li><a href="/article/2830.htm" title="Oracle 复习笔记之序列" target="_blank">Oracle 复习笔记之序列</a> <span class="text-muted">eksliang</span> <a class="tag" taget="_blank" href="/search/Oracle+%E5%BA%8F%E5%88%97/1.htm">Oracle 序列</a><a class="tag" taget="_blank" href="/search/sequence/1.htm">sequence</a><a class="tag" taget="_blank" href="/search/Oracle+sequence/1.htm">Oracle sequence</a> <div>转载请出自出处:http://eksliang.iteye.com/blog/2098859 1.序列的作用 序列是用于生成唯一、连续序号的对象 一般用序列来充当数据库表的主键值 2.创建序列语法如下:   create sequence s_emp start with 1 --开始值 increment by 1 --増长值 maxval</div> </li> <li><a href="/article/2957.htm" title="有“品”的程序员" target="_blank">有“品”的程序员</a> <span class="text-muted">gongmeitao</span> <a class="tag" taget="_blank" href="/search/%E5%B7%A5%E4%BD%9C/1.htm">工作</a> <div>完美程序员的10种品质     完美程序员的每种品质都有一个范围,这个范围取决于具体的问题和背景。没有能解决所有问题的   完美程序员(至少在我们这个星球上),并且对于特定问题,完美程序员应该具有以下品质:   1. 才智非凡- 能够理解问题、能够用清晰可读的代码翻译并表达想法、善于分析并且逻辑思维能力强   (范围:用简单方式解决复杂问题)   </div> </li> <li><a href="/article/3084.htm" title="使用KeleyiSQLHelper类进行分页查询" target="_blank">使用KeleyiSQLHelper类进行分页查询</a> <span class="text-muted">hvt</span> <a class="tag" taget="_blank" href="/search/sql/1.htm">sql</a><a class="tag" taget="_blank" href="/search/.net/1.htm">.net</a><a class="tag" taget="_blank" href="/search/C%23/1.htm">C#</a><a class="tag" taget="_blank" href="/search/asp.net/1.htm">asp.net</a><a class="tag" taget="_blank" href="/search/hovertree/1.htm">hovertree</a> <div>本文适用于sql server单主键表或者视图进行分页查询,支持多字段排序。KeleyiSQLHelper类的最新代码请到http://hovertree.codeplex.com/SourceControl/latest下载整个解决方案源代码查看。或者直接在线查看类的代码:http://hovertree.codeplex.com/SourceControl/latest#HoverTree.D</div> </li> <li><a href="/article/3211.htm" title="SVG 教程 (三)圆形,椭圆,直线" target="_blank">SVG 教程 (三)圆形,椭圆,直线</a> <span class="text-muted">天梯梦</span> <a class="tag" taget="_blank" href="/search/svg/1.htm">svg</a> <div>SVG <circle> SVG 圆形 - <circle> <circle> 标签可用来创建一个圆: 下面是SVG代码: <svg xmlns="http://www.w3.org/2000/svg" version="1.1"> <circle cx="100" c</div> </li> <li><a href="/article/3338.htm" title="链表栈" target="_blank">链表栈</a> <span class="text-muted">luyulong</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E7%BB%93%E6%9E%84/1.htm">数据结构</a> <div> public class Node { private Object object; private Node next; public Node() { this.next = null; this.object = null; } public Object getObject() { return object; } public</div> </li> <li><a href="/article/3465.htm" title="基础数据结构和算法十:2-3 search tree" target="_blank">基础数据结构和算法十:2-3 search tree</a> <span class="text-muted">sunwinner</span> <a class="tag" taget="_blank" href="/search/Algorithm/1.htm">Algorithm</a><a class="tag" taget="_blank" href="/search/2-3+search+tree/1.htm">2-3 search tree</a> <div>  Binary search tree works well for a wide variety of applications, but they have poor worst-case performance. Now we introduce a type of binary search tree where costs are guaranteed to be loga</div> </li> <li><a href="/article/3592.htm" title="spring配置定时任务" target="_blank">spring配置定时任务</a> <span class="text-muted">stunizhengjia</span> <a class="tag" taget="_blank" href="/search/spring/1.htm">spring</a><a class="tag" taget="_blank" href="/search/timer/1.htm">timer</a> <div>最近因工作的需要,用到了spring的定时任务的功能,觉得spring还是很智能化的,只需要配置一下配置文件就可以了,在此记录一下,以便以后用到:     //------------------------定时任务调用的方法------------------------------ /** * 存储过程定时器 */ publi</div> </li> <li><a href="/article/3719.htm" title="ITeye 8月技术图书有奖试读获奖名单公布" target="_blank">ITeye 8月技术图书有奖试读获奖名单公布</a> <span class="text-muted">ITeye管理员</span> <a class="tag" taget="_blank" href="/search/%E6%B4%BB%E5%8A%A8/1.htm">活动</a> <div>ITeye携手博文视点举办的8月技术图书有奖试读活动已圆满结束,非常感谢广大用户对本次活动的关注与参与。 8月试读活动回顾: http://webmaster.iteye.com/blog/2102830 本次技术图书试读活动的优秀奖获奖名单及相应作品如下(优秀文章有很多,但名额有限,没获奖并不代表不优秀): 《跨终端Web》 gleams:http</div> </li> </ul> </div> </div> </div> <div> <div class="container"> <div class="indexes"> <strong>按字母分类:</strong> <a href="/tags/A/1.htm" target="_blank">A</a><a href="/tags/B/1.htm" target="_blank">B</a><a href="/tags/C/1.htm" target="_blank">C</a><a href="/tags/D/1.htm" target="_blank">D</a><a href="/tags/E/1.htm" target="_blank">E</a><a href="/tags/F/1.htm" target="_blank">F</a><a href="/tags/G/1.htm" target="_blank">G</a><a href="/tags/H/1.htm" target="_blank">H</a><a href="/tags/I/1.htm" target="_blank">I</a><a href="/tags/J/1.htm" target="_blank">J</a><a href="/tags/K/1.htm" target="_blank">K</a><a href="/tags/L/1.htm" target="_blank">L</a><a href="/tags/M/1.htm" target="_blank">M</a><a href="/tags/N/1.htm" target="_blank">N</a><a href="/tags/O/1.htm" target="_blank">O</a><a href="/tags/P/1.htm" target="_blank">P</a><a href="/tags/Q/1.htm" target="_blank">Q</a><a href="/tags/R/1.htm" target="_blank">R</a><a href="/tags/S/1.htm" target="_blank">S</a><a href="/tags/T/1.htm" target="_blank">T</a><a href="/tags/U/1.htm" target="_blank">U</a><a href="/tags/V/1.htm" target="_blank">V</a><a href="/tags/W/1.htm" target="_blank">W</a><a href="/tags/X/1.htm" target="_blank">X</a><a href="/tags/Y/1.htm" target="_blank">Y</a><a href="/tags/Z/1.htm" target="_blank">Z</a><a href="/tags/0/1.htm" target="_blank">其他</a> </div> </div> </div> <footer id="footer" class="mb30 mt30"> <div class="container"> <div class="footBglm"> <a target="_blank" href="/">首页</a> - <a target="_blank" href="/custom/about.htm">关于我们</a> - <a target="_blank" href="/search/Java/1.htm">站内搜索</a> - <a target="_blank" href="/sitemap.txt">Sitemap</a> - <a target="_blank" href="/custom/delete.htm">侵权投诉</a> </div> <div class="copyright">版权所有 IT知识库 CopyRight © 2000-2050 E-COM-NET.COM , All Rights Reserved. <!-- <a href="https://beian.miit.gov.cn/" rel="nofollow" target="_blank">京ICP备09083238号</a><br>--> </div> </div> </footer> <!-- 代码高亮 --> <script type="text/javascript" src="/static/syntaxhighlighter/scripts/shCore.js"></script> <script type="text/javascript" src="/static/syntaxhighlighter/scripts/shLegacy.js"></script> <script type="text/javascript" src="/static/syntaxhighlighter/scripts/shAutoloader.js"></script> <link type="text/css" rel="stylesheet" href="/static/syntaxhighlighter/styles/shCoreDefault.css"/> <script type="text/javascript" src="/static/syntaxhighlighter/src/my_start_1.js"></script> </body> </html>