前端的一些坑,一些记录,一些冷知识

简介:

大概从 17 年的六月份开始记录吧,也已经一年了,其中也包含了一些很简单的知识,以前还觉得挺难的,现在看起来有点谜之感慨...

JavaScript

所有对象都有 __proto__ 属性,都指向创造对象的函数对象的 prototype

上传文件要使用 formdata 包装。

Promise.prototype.catch 方法是 .then(null,rejection) 的别名。

同一个 EventTarget 注册了多个相同的 EventListener,那么重复的实例会被抛弃。所以这么做不会使得 EventListener 被调用两次,也不需要用 removeEventListener 手动清除多余的EventListener,因为重复的都被自动抛弃了。

当使用 addEventListener() 为一个元素注册事件的时候,句柄里的 this 值是该元素的引用。其与传递给句柄的 event 参数的 currentTarget 属性的值一样,而 target 是直接接受事件的子元素。

scrollIntoView() 使 div 底部滚动到视窗。

使用 const 的对象和数组的内容是可以被修改的,但数据结构不可变。

在 webpack 里,所有的文件都是模块。loader 的作用就是把文件转换成 webpack 可以识别的模块。

关于事件循环,执行下一个 task 之前总会清空 microtask。

npm 新旧版本覆盖可能会造成迷之问题,这个时候可以试试 node_module 整个删掉重装。

*/- 操作符都是数字运算专用的。当这些运算符与字符串一起使用时,会强制转换字符串为数字类型的值。

document.title 可以直接修改当前 html 的标题。

利用对象浅拷贝修改对象,指向同一对象的两个变量修改对象的效果一样。

脑洞题:1 和 2 只用一次的情况下怎么得到 4 答案:1<<2。

连等赋值从右到左。

compositionstart 事件触发于一段文字的输入之前(类似于 keydown 事件,但是该事件仅在若干可见字符的输入之前,而这些可见字符的输入可能需要一连串的键盘操作、语音识别或者点击输入法的备选词)。

void0(void后面加任何东西)用于生成一个绝对的 undefined(不会被重定义),但跟函数会有副作用

注意 localStorage 保存的只能是字符串,所以是没有 null 的。

坑一个:

 
  1.    typeof [] === 'object' // true

  2.    typeof null === 'object' // true

import 同步,require异步(待补充)。

new() 做了些什么?

 
  1.    var obj = new Base();

  2.    var obj  = {};

  3.    obj.__proto__ = Base.prototype;

  4.    Base.call(obj);

stage 0 到 4 的含义:

  • stage 0 is "i've got a crazy idea",

  • stage 1 is "this idea might not be stupid",

  • stage 2 is "let's use polyfills and transpilers to play with it",

  • stage 3 is "let's let browsers implement it and see how it goes",

  • stage 4 is "now it's javascript".

Object.getOwnPropertyNames(obj).length===0 判断 obj 是不是空对象。

getBoundingClientRect() 用于获取元素宽高以及距离页面边框距离,十分方便。

&& 的使用场景:左边为真继续执行右边,如 isDog&&bark()

|| 的使用场景:左边为假继续执行右边,如 leti=value||defalutValue

Vue.js

v-model 会自动 bind 一个值,其变量名为 value。

多个特性的元素应该分多行撰写,每个特性一行。以下为 vscode 里 vetur 的设置:

 
  1.    "vetur.format.defaultFormatterOptions": {

  2.        "js-beautify-html": {

  3.          "wrap_attributes": "force"

  4.        }

  5.      }

组件 destroy 时触发自定义指令的 unbind,destory 的时机:diff 之后的 patch,如 v-if,v-for(key不同时,先销毁原来的,再挂载新的(推测))

自定义组件 v-model watch 自动匹配(存疑

组件的 data 属性要用函数返回的原因:创建实例时如果 data 是一个对象的话,所有实例都会引用同一个对象,而对象返回不会有此问题。在浏览器中可以这么做是因为根实例只有一个。

.vue 文件中使用 /deep/ 覆盖子组件 css。

GitHub

从 commit 关闭 issues 的方法:commit 信息写 Fixes#33,其他关键字还有 close closes closed fix fixesfixedresolve resolves resolved

git reset--soft HEAD^ 回退一次 commit。

CSS

div 的默认宽度是父元素宽的 100%。

逐帧动画 animation:animate-name3ssteps(每次循环的帧数)infinite;

 
  1.    @keyframes animate-name{

  2.        from{

  3.        <!--原位-->

  4.            background-position: 0 0;

  5.        }

  6.        to{

  7.        <!--最后一帧-->

  8.            background-position: -1540px 0 ;

  9.        }

  10.    }

"Break out" of a parent's containing width to take the full screen of a page w/this nice utility class:

 
  1.    .full-width {

  2.      width: 100vw;

  3.      position: relative;

  4.      left: 50%;

  5.      right: 50%;

  6.      margin-left: -50vw;

  7.      margin-right: -50vw;

  8.    }

行内元素与下一个元素中间有空格(正常排版),会引起一些诡异的缝隙,常见的例如元素之间有间隔,或看起来空了一行(像加了padding)。

pre 标签设置自动换行: white-space:pre-wrap;

隐藏一个元素,同时让这个元素的宽度可获取:设置 overflow:hidden,可以根据元素高度裁剪视区,设置 height:0;overflow:hidden。虽然文档流中占用了位置,由于高度为 0,最终表现特征达到了我们期望的 display:none。此时该元素 clientHeightoffsetHeight 为 0,但是 scrollHeight 是有值的。

scrollHeight 是一个元素没有滚动条时的所有内容高度,当一个元素没有滚动条时 scrollHeight===offsetHeight

当 Render Tree 中部分或全部元素的尺寸、结构、或某些属性发生改变时,浏览器重新渲染部分或全部文档的过程称为回流。

当页面中元素样式的改变并不影响它在文档流中的位置时(例如:color、background-color、visibility等),浏览器会将新样式赋予给元素并重新绘制它,这个过程称为重绘。

回流必将引起重绘,重绘不一定会引起回流。

移动端优化常用 CSS 属性:

 
  1.    user-select: none; // 禁止文字被选中

  2.    outline:none; // 去除点击外边框,点击无轮廓

  3.    -webkit-touch-callout: none; // 长按链接不弹出菜单

  4.    -webkit-tap-highlight-color: rgba(0,0,0,0); // 去除点击高亮

@keyframes 的属性要前后对应,否则不形成动画。

img 元素图像自适应居中,与 background-size 效果一样:

 
  1.    object-fit: cover;

<img/> 标签千万记得写宽高,不然会花式塌陷。

flex-grow 所在元素如果未定宽度的话,宽度会被子元素撑开。

一个英文单词默认不换行,无论多长,所以要设置 wordbreak

多行文字居中:

 
  1.    .mulit_line{

  2.        border:1px dashed #cccccc;

  3.        padding-left:5px;

  4.    }

  5.    .mulit_line span{

  6.        display:inline-block;

  7.        line-height:14px;

  8.        vertical-align:middle;

  9.    }

safari 中控制惯性滚动 -webkit-overflow-scroll

滚动条样式可能使滚动条强制显示(未确定)。

flex 布局不换行加 flex-shrink:0; 实现 div 不压缩无限并排,可以用于 swiper 等场景。

巧用猫头鹰选择器 *+*

float 自带 display:block

鼠标禁用 .disabled{pointer-events:none;}

注意 :last-child:last-of-type 的区别。

::after 表示法是在 CSS3 中引入的, :: 符号是用来区分伪类和伪元素的。支持CSS3的浏览器同时也都支持 CSS2 中引入的表示法 :after

父元素如果存在 transform 属性,子元素的 position:fixed 属性无效。

less 中的 calc 问题: height:calc(~"100% - 50px");

vh 在部分浏览器中包含地址栏部分,小心使用。

VSCode

alt + shift + 鼠标点击 纵向选择。

vetur 分号问题:安装 prettier,然后配置 "prettier.singleQuote":true,"prettier.semi":false

可以使用插件 document this 方便写注释。

html tag 属性分行 wrap_attributes:force

选定变量后按 F12 找到定义位置。

其他

魔法隧道用 webpack 代理会 502。

在组件化编程中,悼念被同名组件浪费了几个钟的 debug 时间[蜡烛]。

局域网连不通的话,先试试,开共享,关闭防火墙。

局域网连不通的话,还可以试试,在 webpack.config.js 文件的 devServer 里加上 host:'0.0.0.0'

iOS 的回弹效果,动的是 body 部分,html 是不动的。

学习一个语言之前先看规范。

safari 的 formdata 只支持 append,其他方法需要 polyfill。

rc 的意思是 run commands。

导航栏高度 88px,标签栏高度 98px(iphone5和6常用)。

关于 HTTP 304 Not Modified,简单来说,请求内容没有发生变化的时候,根据设置,服务器可能直接取缓存返回。


原文发布时间为:2018-10-4 本文作者:ssshooter 本文来自云栖社区合作伙伴“前端大学”,了解相关信息可以关注“前端大学”。

相关文章
|
3月前
|
存储 缓存 NoSQL
数据的存储--Redis缓存存储(一)
数据的存储--Redis缓存存储(一)
150 1
|
8月前
|
NoSQL 关系型数据库 Redis
DMS问题之归档后数据量和大小没变化如何解决
DMS(Data Management Service)是阿里云提供的一站式数据管理服务,支持数据开发、维护、治理等多种功能;本合集着重于介绍DMS的功能特点、操作流程和最佳实践,帮助用户高效进行数据管理和维护。
|
3月前
|
存储 缓存 NoSQL
数据的存储--Redis缓存存储(二)
数据的存储--Redis缓存存储(二)
59 2
数据的存储--Redis缓存存储(二)
|
6月前
|
SQL canal Serverless
Serverless 应用引擎使用问题之每次记录的数据很少,如何不使用外链数据库储存数据
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
|
7月前
|
运维 关系型数据库 分布式数据库
PolarDB产品使用问题之表更新频繁,读取频繁,导致有很多慢日志,时间还很高,该怎么办
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
8月前
|
存储 关系型数据库 MySQL
如何处理爬取到的数据,例如存储到数据库或文件中?
处理爬取的数据,可存储为txt、csv(适合表格数据)或json(适合结构化数据)文件。若需存储大量数据并执行复杂查询,可选择关系型(如MySQL)或非关系型(如MongoDB)数据库。以MySQL为例,需安装数据库和Python的pymysql库,创建数据库和表,然后编写Python代码进行数据操作。选择存储方式应考虑数据类型、数量及后续处理需求。
116 1
|
SQL 数据挖掘 数据管理
时间回溯 | 如何按需极速查询数据库实例的历史数据?
未来数据库备份DBS团队及数据管理团队会进一步挖掘备份数据的使用价值,在闪回,数据变更轨迹,数据订正,历史数据分析等领域为用户提供更多的可能。
时间回溯 | 如何按需极速查询数据库实例的历史数据?
|
存储 监控 安全
80%以上是冷数据!昆腾的数据归档之道
中国的冷、温、热数据分别占比80%、15%和5%,冷数据是最多的。而对于冷数据来说,计算不是常态,主要是存储。中国算力中心的“存力”相对不足,中国数据存储产业大有可为。
303 0
80%以上是冷数据!昆腾的数据归档之道
|
存储 对象存储
归档存储
归档存储
411 0
|
存储 弹性计算 容灾
实战宝典 | 如何让备份数据秒级可用,随时查询历史数据?
盘活二级数据的方案,从解决方案的角度是成立的,但实施起来面临着许多技术困难。CDM是备份技术领域近几年备受关注的技术方向。业界对于CDM的定义各有一些不同,在数据库领域,我们认为CDM是多项技术组合而成的解决方案,目的是帮助用户更快速、低成本的保存和使用数据库备份数据。阿里云数据库备份产品DBS,运用了业界领先的CDM(Copy Data Management)技术,提供了完全克服以上技术困难的整体解决方案——DBS沙箱,帮助用户全面激活从备份数据到二级数据库业务生态。
2541 0
实战宝典 | 如何让备份数据秒级可用,随时查询历史数据?