最后
四轮技术面+一轮hr面结束,学习到了不少,面试也是一个学习检测自己的过程,面试前大概复习了 一周的时间,把以前的代码看了一下,字节跳动比较注重算法,面试前刷了下leetcode和剑指offer, 也刷了些在牛客网上的面经。大概就说这些了,写代码去了~
祝大家都能收获大厂offer~
篇幅有限,仅展示部分内容
使用 State 跟普通 JavaScript 相比,它的好处是:
-
在组件内部管理状态,代码封装性好,出错的话也容易定位到问题组件。
-
数据和展示分离,只需要修改 state 的值,就能更新对应的组件。
-
state 可以通过 props 向下传递给其他组件,只要 state 改变,所有使用它的组件都会刷新。
接下来看一下这个例子怎么实现。
首先还是要创建一个 raect 工程,用 create react app。
- 使用 create-react-app 创建一个工程:
yarn create react-app react-gradient-bg
等同于
npx create-react-app react-gradient-bg
工程创建好之后,咱们在 src 里面创建一个新的组件 (也就是文件夹) 叫 Gradient
。
这个简单的示例的代码整个都在这个 gradient 组件里边。他有两个颜色选>择器。然后一个重置按钮。整个背景是由用户选择的两个颜色组成的一个 75 度的渐变。当用户在选择颜色的时候,这个背景会动态的根据用户选择的颜色发生变化,点击重置按钮之后,背景颜色会变成初始的默认值。
咱们先来看 html 的结构。
编写 html 结构
function Gradient() {
重置为默认
;}
这里:
-
定义了两个
type
为color
的input
,这是 html 原生的颜色选择器组件, 如果浏览器不支持就会变成颜色输入框,可以输入#FFFFFF 之类的颜色值。 -
定义了一个重置按钮。
-
样式可以在源代码中查看。
创建 state
创建 state 用 react 内置的 useState
hook。
// 设置两个 state,给默认值
const [color1, setColor1] = useState(“#00F260”);
const [color2, setColor2] = useState(“#0575E6”);
-
它接受一个参数,是 state 的默认值,然后返回一个数组,数组里面有两个元素,第 1 个元素是 state 的值,然后第 2 个元素是改变这个 state 的函数。
-
这里定义了两个 color state。
接着给最外层容器 div 设置一个 style,让它的背景色为渐变的,使用这两个 color 的值:
return (
className={styles.container}
style={{
background: linear-gradient(75deg, ${color1}, ${color2})
}}
// …
处理 input 事件
接下来就是处理这两个颜色状态的改变,表单元素 input、 select 等会触发 onChange
这个事件,也就是说当用户在里边输入值或者是选择选项的时候。
咱们可以在这个组件的函数里边,先定义一个处理函数。比如说叫 handleInputChange
:
function handleInputChange(e) {
const { name, value } = e.target;
// 使用 name 区分,这里也可以用 switch
if (name === “color1”) {
setColor1(value);
} else if (name === “color2”) {
setColor2(value);
}
}
-
react 会在触发事件的时候,给事件处理函数传递一个参数
event
,代表这个事件它的本身,但是这个事件是合成的,它不是原生的 html 的 event,不过它里面的属性和 html 的基本上一样。 -
这个
event
里面有一个target
属性,就是说是谁触发了一个事件,那这里就是这两个 input。 -
获取到 input 的 target 之后就可以获取到 input 标签里面的属性,比如说
name
和value
。 -
后面可以根据 name 来区分是哪个 input 触发的事件,然后把新的颜色用
setXXX
的函数,来把颜色更新。
最后把处理函数和状态的值添加到 input 组件上,注意在 JSX 里边,html 的属性都是驼峰命名法,不是全部小写的那种:
<input
type=“color”
name=“color1”
className={styles.inputColor}
value={color1}
onChange={handleInputChange}
/>
<input
type=“color”
总结
- 对于框架原理只能说个大概,真的深入某一部分具体的代码和实现方式就只能写出一个框架,许多细节注意不到。
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
-
算法方面还是很薄弱,好在面试官都很和蔼可亲,擅长发现人的美哈哈哈…(最好多刷一刷,不然影响你的工资和成功率???)
-
在投递简历之前,最好通过各种渠道找到公司内部的人,先提前了解业务,也可以帮助后期优秀 offer 的决策。
-
要勇于说不,对于某些 offer 待遇不满意、业务不喜欢,应该相信自己,不要因为当下没有更好的 offer 而投降,一份工作短则一年长则 N 年,为了幸福生活要慎重选择!!!
第一次跳槽十分忐忑不安,和没毕业的时候开始找工作是一样的感受,真的要相信自己,有条不紊的进行。如果有我能帮忙的地方欢迎随时找我,比如简历修改、内推、最起码,可以把烦心事说一说,人嘛都会有苦恼的~
祝大家都有美好的未来,拿下满意的 offer。