自我梳理 - 日理万妓 2022-01-19 03:25 270阅读 0赞 ## 知识架构 ## ### html的语义化 ### 其实前端大多数情况下是可以靠div和span就能搭建一个基本的网站,但是语义化也有语义化的意义, 1. 更适合机器阅读,如引擎搜索,又如盲人阅读器 2. 使结构更明确,即使没有css的情况下,也可以清晰看出网页的结构 很多情况下,我们说话没有唯一的表达方式,语义话标签的使用也是这样,下面是几个使用场景。 * 作为纯文本的补充,用于表达一定的结构或者消除歧义 今天我吃了一个苹果 可以表述为 <em>今天</em>我吃了一个苹果 今天我吃了<em>一个</em>苹果 今天我吃了一个<em>苹果</em> 复制代码 * 作为标题摘要的语义类标签 <h1>HTML语义</h1> <p>balah balah balah balah</p> <h2>弱语义</h2> <p>balah balah</p> <h2>结构性元素</h2> <p>balah balah</p> 复制代码 当h元素放在section中时,h的层级会下降 <section> <h1>大标题</h1> <p>balbalba</p> <h2>小标题</h2> <p>balaala</p> <h2>小标题2</h2> <p>balabal</p> </section> 复制代码 一个典型的body <body> <header> <nav> …… </nav> </header> <aside> <nav> …… </nav> </aside> <section>……</section> <section>……</section> <section>……</section> <footer> <address>……</address> </footer> </body> 复制代码 部分标签的意义 * aside -- 导航性质的工具内容(侧边栏) * nav -- 导航(目录、导航栏、超链接) * article -- 文章 * abbr -- 缩写 * hr -- 效果为一条横线,意义为故事走向的转变或话题的转变 * strong -- 强调 表现为加粗 * time -- 时间 * figure, figcaption -- 与主文章相关的图像、照片等流内容 * dfn -- 被定义的元素 * pre -- 预定义的内容,不需要浏览器进行排版 * code -- 代码 * small -- 补充评论 * s -- 错误的内容,如打折前的价格,表现为中间的一条横线 * i -- 表示读的时候变调 * b -- 表示关键字 * u -- 表示避免歧义的标注 * data -- 和time类似,只是给机器读的内容 * menu -- ul的变体,用于功能菜单时使用 * main -- 整个页面只出现一个,表示页面的主要内容,可以理解为特殊的div ### javascript类型 ### * undefined -- 未定义 一个变量 而不是关键字 我们可以使用 void 0 来获取undefined值,防止undefined被篡改 * null -- 定义了 但是是空值 * boolean * string -- 有长度限制的字符串 * number 注意 +0 和 -0相加时没有区别 但是除法时,1/0 = Infinity 1/-0 = -Infinity 小数相加有精度问题 判断可以这么判断,javaScript提供的最小精度值:Number.EPSILON console.log( Math.abs(0.1 + 0.2 - 0.3) <= Number.EPSILON); 复制代码 * symbol -- 一切非字符串的对象key的集合,es6引入的新类型 var mySymbol = Symbol("my symbol"); 复制代码 * object -- 属性的集合 属性分为数据属性和访问器属性,两者都是key-value结构,key可以是字符串或Symbol类型 Number/String/Boolean/Symbol都有自己的创建对象方法,如 new Number(2); --> 对象类型 对象的方法也可以在基本类型上使用 ,如 cosole.log("abc".charAt(0)); //a 复制代码 当与new搭配时,他们产生对象,当直接调用时,他们表示强制类型转换 但symbol不同,直接new会报错 问题:为什么给对象添加的方法能用在基本类型上? 因为运算符提供了装箱操作,它会根据基础类型构建一个临时对象,使得我们能在基础类型上调用对应对象的方法. ### 类型转换 ### 最好不要使用 == 比较, 而在显示地类型转换后使用 === 比较,因为试图实现跨类型的比较,它的规则复杂到没人能记住 === 的比较规则 **string to number** parseInt/parseFloat/Number 我们知道 0b --> 二进制 0o --> 八进制 0x -- >十进制,但是一些比较老的浏览器会识别错误,所以转化时应该传入parseInt的第二个参数,指定明确转化进制 ### 装箱转换 ### 每一种基本类型Number、String、Boolean、Symbol在对象中都有对应的类,所谓装箱转换,正是把基本类型转换为对应的对象,它是类型转换中一种相当重要的种类。 那么Symbol函数无法new出对应的对象,但我们仍可以利用函数的call方法来强迫产生装箱 var symbolObject = (function(){ return this; }).call(Symbol("a")); console.log(typeof symbolObject); //object console.log(symbolObject instanceof Symbol); //true console.log(symbolObject.constructor == Symbol); //true 复制代码 更好的方法是使用内置的Object函数 var symbolObject = Object((Symbol("a")); console.log(typeof symbolObject); //object console.log(symbolObject instanceof Symbol); //true console.log(symbolObject.constructor == Symbol); //true 复制代码 每一类装箱对象皆有私有的 Class 属性,这些属性可以用 Object.prototype.toString 获取: var symbolObject = Object((Symbol("a")); console.log(Object.prototype.toString.call(symbolObject)); //[object Symbol] 复制代码 在 JavaScript 中,没有任何方法可以更改私有的 Class 属性,因此Object.prototype.toString 是可以准确识别对象对应的基本类型的方法,它比 instanceof 更加准确。 call操作本身会产生装箱操作,需要配合typeod来区分基本类型和对象类型. ### 拆箱转换 ### 先拆箱再转换,拆箱转换会尝试调用 valueOf 和 toString 来获得拆箱后的基本类型。如果 valueOf 和 toString 都不存在,或者没有返回基本类型,则会产生类型错误 TypeError。 number先执行valueOf再执行toString var o = { valueOf : () => {console.log("valueOf"); return {}}, toString : () => {console.log("toString"); return {}} } o * 2 // valueOf // toString // TypeError 复制代码 string先执行toString再执行valueOf 新版google也是先valueOf再toString var o = { valueOf : () => {console.log("valueOf"); return {}}, toString : () => {console.log("toString"); return {}} } o + "" // valueOf // toString // TypeError 复制代码 在 ES6 之后,还允许对象通过显式指定 @@toPrimitive Symbol 来覆盖原有的行为。 var o = { valueOf : () => {console.log("valueOf"); return {}}, toString : () => {console.log("toString"); return {}} } o[Symbol.toPrimitive] = () => {console.log("toPrimitive"); return "hello"} console.log(o + "") // toPrimitive // hello 复制代码 事实上,“类型”在 JavaScript 中是一个有争议的概念。一方面,标准中规定了运行时数据类型; 另一方面,JS语言中提供了 typeof 这样的运算,用来返回操作数的类型,但 typeof 的运算结果,与运行时类型的规定有很多不一致的地方。我们可以看下表来对照一下。 转载于:https://juejin.im/post/5cbe89805188250aae56a03a
相关 自我鼓励 > 看到很久之前阿里巴巴的一段话,深有感触,便抄录下来。 任何团队的核心骨干,都必须学会在没有鼓励、没有认可、没有帮助、没有理解、没有宽容、没有退路,只有压力的情况下,一起和 曾经终败给现在/ 2022年06月13日 03:20/ 0 赞/ 159 阅读
相关 自我提升 一、清晨7问:我今天的目标是什么? 我的终极人生目标是什么? 今天最重要的一件事是什么? 我今天如何与周围的人相处? 我今天要学哪些新知识? 我今天要有怎样的心情? 我今天 你的名字/ 2022年05月22日 09:51/ 0 赞/ 220 阅读
相关 梳理 (一)梳理思路 搭建项目结构 搭建前端环境,技术准备,git 前后端分离的思想,开发的流程,mybatisplus的入门 商品品牌和分类,以及crud实现、高级查询 「爱情、让人受尽委屈。」/ 2022年02月02日 17:21/ 0 赞/ 236 阅读
相关 自我梳理 知识架构 html的语义化 其实前端大多数情况下是可以靠div和span就能搭建一个基本的网站,但是语义化也有语义化的意义, 1. 更适合机器阅读,如引擎搜索, - 日理万妓/ 2022年01月19日 03:25/ 0 赞/ 271 阅读
相关 自我介绍 自我感觉我是一个话比较少而且很随和的人,我的兴趣爱好也很多,喜欢的运动有篮球,乒乓球,羽毛球等。自从进入这个这个学校后,也结交许多朋友,。其实我也是一个比较慢热的人,对于刚认识 Love The Way You Lie/ 2022年01月07日 04:55/ 0 赞/ 300 阅读
相关 自我介绍 我是一个比较内向的人,平时喜欢一个人待着,不喜欢去喧闹的地方,所以平时的爱好就是听听歌,看看书,下下棋。个人从初中就从计算机比较感兴趣,高考后也不知道选什么专业,便凭着自己的兴 墨蓝/ 2022年01月05日 02:41/ 0 赞/ 387 阅读
相关 自我介绍 我叫李双贵,来自湖南衡阳。在陌生人或者不是特别熟悉的人面前,我会表现得有点内向,但是呢,我希望我能改变这个缺点,在别人面前,勇于去表现自己,我对自己还是挺有信心的。还有,我觉得 痛定思痛。/ 2021年12月24日 15:43/ 0 赞/ 325 阅读
相关 自我介绍 我叫王磊,是一个性格比较内向的人,不过比较随和与人相处也比较友善。虽然和陌生人交流比较少。在学习方面的话,我的自控能力还不行,往往没办法做到把学习掌控的很好。 转载于:htt 偏执的太偏执、/ 2021年12月24日 12:29/ 0 赞/ 362 阅读
相关 自我介绍 我是邱志伟,物联网专业,平时比较喜欢看一些文学作品,最爱的诗人是林徽因,对于她和梁思成,徐志摩,金岳霖的那一段往事儿格外的感兴趣,平时也打打游戏,写写作,空了再弹弹尤克里里。算 悠悠/ 2021年09月20日 13:42/ 0 赞/ 421 阅读
相关 塑造自我 > 谁也无法说服他人改变,因为我们每个人都守着一扇只能从内开启的改变之门,不论动之以情或晓之以理,我们都不能替别人开门。——Marilyn Ferguson 塑造自我 小咪咪/ 2021年06月24日 16:11/ 0 赞/ 438 阅读
还没有评论,来说两句吧...