前端每日一题笔记收集
-
在元素
input
中,若未定义name
的属性,在后台获取了填入该input
中的值么?- 后台确实获取了该元素的值,但是不知道该怎么用,不会在后台中显示出来
-
使用一个
box-shadow
和多个box-shadow
在样式展现上有什么区别么?为什么要使用多个?- 叠加,效果好看
-
a
标签的download
属性是做什么?- 此属性指示浏览器下载 URL 而不是导航到它,因此将提示用户将其保存为本地文件。
<a href="./img/img01.jpg" download="dog.jpg">下载图片</a>
- 参考MDN
-
form
标签的method
属性是做什么的?有哪些取值?- 用来设置提交表单的方式,常见的取值有
get
和post
- 参考MDN
- 用来设置提交表单的方式,常见的取值有
-
ruby
标签是做什么?- 用来展示东亚文字注音或字符注释
-
参考MDN
<ruby> 明 日 <rp>(</rp><rt>ming ri</rt><rp>)</rp> </ruby>
-
HTML
标签的tabindex
属性是做什么的?它的值为正、为负、为零时分别表示什么意思?- 指示其元素是否可以聚焦,以及它是否/在何处参与顺序键盘导航(通常使用Tab键,因此得名)。
- tabindex=负值 (通常是tabindex=“-1”),表示元素是可聚焦的,但是不能通过键盘导航来访问到该元素,用JS做页面小组件内部键盘导航的时候非常有用。
- tabindex="0" ,表示元素是可聚焦的,并且可以通过键盘导航来聚焦到该元素,它的相对顺序是当前处于的DOM结构来决定的。
- tabindex=正值,表示元素是可聚焦的,并且可以通过键盘导航来访问到该元素;它的相对顺序按照tabindex 的数值递增而滞后获焦。如果多个元素拥有相同的 tabindex,它们的相对顺序按照他们在当前DOM中的先后顺序决定。
- 参考MDN
-
HTML
中的【空元素】是什么?- 一个空元素(empty element)可能是 HTML,SVG,或者 MathML 里的一个不可能存在子节点(例如内嵌的元素或者元素内的文本)的
element
- 没有闭合的标签,如
<br> 、<input>、<img>
等,称为空元素 - 参考MDN
- 一个空元素(empty element)可能是 HTML,SVG,或者 MathML 里的一个不可能存在子节点(例如内嵌的元素或者元素内的文本)的
-
<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1, maxinum-scale=1, user-scalable=no">
这是手机淘宝页面的代码,请问其作用是什么?其中content
中五个字段分别是什么意思?- 作用是设置 viewport 视口。
width=device-width
意思是视口宽度等于设备宽度。
initial-scale=1
意思是初始缩放为1.
minimum-scale=1
是最小缩放为1.
maximum-scale=1
是最大缩放为1
user-scalable=no
是不允许用户缩放。
- 作用是设置 viewport 视口。
-
CSS选择器
a.item:hover+ul{display: block;}
是什么意思?- 意思是当类为
item
的a
标签被hover
时,它同级后面的ul
标签样式为display: block
- 意思是当类为
-
CSS选择器
[title^=i]
匹配什么样的元素?- 匹配所有
title
属性值以i
开头的元素
- 匹配所有
-
CSS选择器
:not(div):not(span)
匹配什么样的元素?- 匹配
div
和span
以外的所有元素
- 匹配
-
#one {position: sticky ; top: 10px;}
会有什么效果? -
JS的数据类型有哪7个?
number、string、bool、undefined、null、symbol、object
-
JS的
falsy
值有哪5个?0、NaN、''、null、undefined
-
var、let、const的区别是什么?
- var 声明的变量属于函数作用域,let 和 const 声明的变量属于块级作用域;
- var 存在变量提升现象,而 let 和 const 不存在变量提升;
- var 变量可以重复声明,而在同一个块级作用域,let变量不能重新声明,const 变量不能修改。
-
const a = {name: 'a'}; const b = a; b.name = 'b';
请问现在a.name
的值是多少?为什么?- 值是
b
,因为b和a引用了同一个对象,改变b.name
的值就会改变a.name
的值
- 值是
-
const fn = ()=>{console.log(this)}; fn.call("hi")
,请问打印出来的this
的值是什么?为什么?-
this
的值是window
,因为箭头函数里面的this
就是外面的this
,而外面的this
默认是window
-
-
function fn(){}; fn.a = 'aaa'
,为什么fn上可以添加a
属性?- 因为函数也是一种对象
-
let name = 'x'; let obj = {name: 'y'}
,请问obj[name]
是多少?undefined
- 因为 1.
obj[name]
等价于obj['x']
2.obj['x']
不存在,为undefined
,所有obj[name]
为undefined
- 如果要访问
y
,则应使用obj.name
或obj['name']
,这两种写法才是等价的
-
function fn(){return '返回值'}
,请问fn
和fn()
的区别是什么?-
fn
是函数名,是一个纸箱一块内存空间的指针,里面存储的是一段代码的地址 -
fn()
是执行fn
这个地址执行的代码片段得到执行结果 -
fn
是一个引用函数(不调用),fn()
是调用一个函数得到返回值(调用了),本题中fn()
等价于'返回值'
,是一个字符串
-
-
function f1(f2){ f2() }
,请问一般应该如何调用f1
,给出代码示例- 给
f1
传一个函数即可: f1(function(){console.log(1)})
f1(()=>{console.log(2)})
let f2 = function(){}; f1(f2)
- 给
-
function f3(){ setTimeout( ()=>{return 123} )}
,问f3
的返回值是多少?- undefined
- 因为 f3 没有 return,默认返回 undefined。setTimeout 里面的 return 是箭头函数的 return,跟 f3 无关。
- 如果函数体内没有return 语句,那么函数默认返回undefined;若函数体内有return语句,那么返回return后面的值,若return语句后面没有跟东西,也返回undefined.
-
functon fn(){}
,请问fn()
和new fn()
有什么区别?- fn() 返回 undefined, new fn() 返回一个用 fn 初始化的对象
- 参考链接
-
如何让一个对象a的proto属性指向另一个对象b,代码中不能使用proto,因为这不是一个标准属性。
1. a=Object.create(b) 2. temp = function(){}; temp.prototype = b; a = new temp();
-
super关键字的做什么用的?
- super可以用来调用父类的构造方法或静态方法。在子类的构造方法中调用时,需要用在this前面
-
mixin是什么?
- 就是把一个对象的属性,复制到另一个对象上(即混入)
- Object.assign是深拷贝还是浅拷贝?
- 浅拷贝,但是不是那么浅。第一层还是深的,第二层就是不是深的类。JS没有提供对象的完全深拷贝方法,需要自己写。
- Object.seal有什么用?
- Object.seal()方法封闭一个对象,阻止添加新属性并将所有现有属性标记为不可配置
- AJAX的全称是什么?其中的X被什么取代了?
- 全称是JavaScript和XML(Async JavaScript And XML),其中XML已经被JSON取代了。
- HTTP中,幂等是什么?
- 幂等的意思是某个操作执行一次和执行任意多次,造成的影响结果相同。比如读取资源(get)对服务器的影响相同,而创建资源(post)一次和多次的结果就不相同
- HTTP中,301和302的区别是什么?
- 301是永久重定向,请求的网页已永久移动到新位置
- 302是临时重定向
- Cookie和LocalStorage的区别是什么?
- Cookie会自动被上传到服务器,LocalStorage不会[自动]被上传到服务器。他们支持的最大存储空间也不同
- LocalStorage和SessionStorage的区别是什么?
- LocalStorage不会自动过期,SessionStorage会在会话结束自动过期
- 类和对象的关系是什么?
- 如果一些对象拥有一样的属性,就是通一类对象,那么我们就可以先创建类,然后把类当作模版来创建对象。
- 类是对象的设计图,对象的类的实现
- 前端MVC中的M、V、C分别代表什么?
- M 是 Model,表示数据,所有跟数据有关的操作放在 M 里。V 是 View,表示视图,所有 DOM 操作都应该放在这里。C 是 Controller,表示控制器,没有什么特定的意思,所有其他操作都放到 C 里。
- 事件委托是什么意思?
- 抽象问题举例回答:加上有3个按钮,我们不用对每个按钮进行一次监听,可以直接监听3个按钮的父容器,然后根据 e.target 的值知道是哪个按钮被点击。
- 发布订阅模式是什么?
- 事件完全可以理解成“信号”,如果存在一个“信号中心”,某个任务执行完成,就向信号中心“发布”(publish)一个信号,其他任务可以向信号中心“订阅”(subscribe)这个信号,从而知道什么时候自己可以开始执行。这就叫做”发布/订阅模式”
- 抽象问题举例回答:发布订阅模式就是有一个 eventBus 对象,提供 .on / .emit / .off 属性,使用 eventBus.on 可以监听事件,使用 eventBus.emit 可以触发事件,eventBus.off 可以取消事件监听
- JS中的模板是什么?
- 抽象问题举例回答:把字符串中的占位符替换成具体的数据,就是模板。比如 compile('Hello {{name}}', {name:'frank'}) 就是一个模板的使用示例。
- Vue的数据响应式原理是什么?
- 答案是 Vue 相关文档的第一页 https://cn.vuejs.org/v2/guide/reactivity.html 复述出来即可得满分
- React的受控组件是什么?
- 答案是 React 相关文档的前两段话 https://www.reactjscn.com/docs/forms.html#%E5%8F%97%E6%8E%A7%E7%BB%84%E4%BB%B6 复述出来即可得满分
- Vue组件的生命周期钩子有哪些?
- beforeCreate / created / beforeMount / mounted / beforeUpdate / updated / beforeDestroy / destroyed
- React组件的生命周期钩子有哪些?
- constructor / getDerivedStateFromProps / render / componentDidMount / shouldComponentUpdate / getSnapshotBeforeUpdate / componentDidUpdate / componentWillUnmount 等
- Vue的methods和computed有什么区别?
- 开放问题,没有标准答案,可参考 https://zhuanlan.zhihu.com/p/33778594
- Vue Router的hash模式和history模式有什么区别?
- 开放问题,主要区别:
一、实现原理不同,前者用锚点,后者用 history API
二、对后端的要求不同,前者不需要后端支持,后者需要后端做页面重定向,所有 URL 都重定向到一个页面
三、其他细节参考 https://juejin.im/post/5a61908c6fb9a01c9064f20a
-
React的class组件和函数组件有什么区别?
主要区别:
一、class 组件主要用 class 和生命周期,函数组件用函数和 hooks API
二、其他参考 https://zhuanlan.zhihu.com/p/62767474 -
Webpack loader和plugin的区别?
- 先翻译成中文,loader 是加载器,loader 用于加载某些资源文件;plugin 是插件,用于扩展webpack的功能。然后分别举例,loader 有什么,plugin 有什么。
- React的Hooks有哪些?分别有什么用?