对于前端防御性编程

  • 咱们大多数状况可能遇到过,后端的因为同时申请人数过多,或者数据量过大,又或者是因为异样导致服务异样,接口申请失败,而后前端呈现白屏或者报错
  • 还有一种状况,是前端本身写的代码存在一些缺点,整个零碎不够强壮,从而会呈现白屏,或者业务零碎异样,用户误操作等
  • 那么,就呈现了前端防御性编程

常见的问题和防备

1.最常见的问题:
uncaught TypeError: Cannot read property 'c' of undefined

呈现这个问题最根本原因是:

当咱们初始化一个对象obj为{}时候,obj.a这个时候是undefined.咱们打印obj.a能够失去undefined,然而咱们打印obj.a.c的时候,就会呈现下面的谬误。js对象中的未初始化属性值是undefined,从undefined读取属性就会导致这个谬误(同理,null也一样)

如何防止?

js和ts目前都呈现了一个可选链概念,例如:

const obj = {};console.log(obj?.b?.c?.d)
下面的代码并不会报错,起因是?.遇到是空值的时候便会返回undefined.
2.前端接口层面的谬误机制捕捉

前端的接口调用,个别都比拟频繁,咱们这时候能够思考应用单例模式,将所有的axios申请都用一个函数封装一层。对立能够在这个函数中catch捕捉接口调用时候的未知谬误,伪代码如下:

function ajax(url,data,method='get'){  const promise = axios[method](url,data)  return  promise.then(res=>{  }).catch(error){  //对立处理错误}}

那么只有产生接口调用的未知谬误都会在这里被解决了

3.谬误边界(Error Boundaries,前端呈现未知谬误时,展现事后设定的UI界面)

以React为例

局部 UI 的 JavaScript 谬误不应该导致整个利用解体,为了解决这个问题,React 16 引入了一个新的概念 —— 谬误边界。

谬误边界是一种 React 组件,这种组件能够捕捉并打印产生在其子组件树任何地位的 JavaScript 谬误,并且,它会渲染出备用 UI,而不是渲染那些解体了的子组件树。谬误边界在渲染期间、生命周期办法和整个组件树的构造函数中捕捉谬误。

应用示例:

class ErrorBoundary extends React.Component {  constructor(props) {    super(props);    this.state = { hasError: false };  }  static getDerivedStateFromError(error) {    // 更新 state 使下一次渲染可能显示降级后的 UI    return { hasError: true };  }  componentDidCatch(error, errorInfo) {    // 你同样能够将谬误日志上报给服务器    logErrorToMyService(error, errorInfo);  }  render() {    if (this.state.hasError) {      // 你能够自定义降级后的 UI 并渲染      return <h1>Something went wrong.</h1>;    }    return this.props.children;   }}
留神
  • 谬误边界无奈捕捉以下场景中产生的谬误:

    • 事件处理(理解更多)
    • 异步代码(例如 setTimeout 或 requestAnimationFrame 回调函数)
    • 服务端渲染
    • 它本身抛出来的谬误(并非它的子组件)
4.前端简单异步场景导致的谬误
  • 这个问题可能远不止这么简略,然而大道至简,遵循单向数据流的形式去扭转数据,例如:

    //test.jsexport const obj = {  a:1,  b:2}//应用objimport {obj} from './test.js';obj.a=3;

当你频繁应用这个obj对象时,你无奈依据代码去晓得它的扭转程序(即在某个时刻它的值是什么),而且这外面可能存在不少异步的代码,当咱们换一种形式,就能晓得它的扭转程序了,也更不便咱们debug

例如:

//test.jsexport const obj = {  a:1,  b:2}export function setObj (key,value)  {  console.log(key,value)  obj[key] = value}
这样,咱们就做到了
5.前端专一“前端”
  • 对于一些敏感数据,例如登录态,鉴权相干的。前端应该是尽量做无感知的转发、携带(这样也不会呈现平安问题)
6.页面做到可降级
  • 对于一些刚上新的业务,或者有存在危险的业务模块,或者会调取不受信赖的接口,例如第三方的接口,这个时候就要做一层降级解决,例如接口调用失败后,剔除对应模块的展现,让用户无感知的应用
7.巧用loading和disabled
  • 用户操作后,要及时loading和disabled确保不让用户进行反复,避免业务侧呈现bug
8.慎用innerHTML
  • 容易呈现安全漏洞,例如接口返回了一段JavaScript脚本,那么就会立刻执行。此时脚本如果是歹意的,那么就会呈现不可预知的结果,特地是电商行业,尤其要留神

❤️ 看完三件事

  • 如果你感觉这篇内容对你挺有启发,我想邀请你帮我三个小忙:
  • 点个「赞」,让更多的人也能看到这篇内容(喜爱不点在看,都是耍流氓 -_-)
  • 关注我,让咱们成为长期关系
  • 关注公众号「前端巅峰」,继续为你推送精选好文,也能够加我为好友,随时聊骚。