当前位置: 首页 > news >正文

网站建设的作用有哪些页面设计源代码

网站建设的作用有哪些,页面设计源代码,找人做网站没有做好报案有用吗,如何找网站建设客户本文来自#React系列教程#xff1a;https://mp.weixin.qq.com/mp/appmsgalbum?__bizMzg5MDAzNzkwNAactiongetalbumalbum_id1566025152667107329) 一. 高阶组件 1.1. 认识高阶组件 什么是高阶组件呢#xff1f;相信很多同学都听说过#xff0c;也用过 高阶函数https://mp.weixin.qq.com/mp/appmsgalbum?__bizMzg5MDAzNzkwNAactiongetalbumalbum_id1566025152667107329) 一. 高阶组件 1.1. 认识高阶组件 什么是高阶组件呢相信很多同学都听说过也用过 高阶函数它们非常相似所以我们可以先来回顾一下什么是 高阶函数。 高阶函数的维基百科定义至少满足以下条件之一 接受一个或多个函数作为输入输出一个函数 JavaScript中比较常见的filter、map、reduce都是高阶函数。 那么什么是高阶组件呢 高阶组件的英文是 Higher-Order Components简称为 HOC官方的定义高阶组件是参数为组件返回值为新组件的函数 我们可以进行如下的解析 首先 高阶组件 本身不是一个组件而是一个函数其次这个函数的参数是一个组件返回值也是一个组件 高阶组件的调用过程类似于这样 const EnhancedComponent higherOrderComponent(WrappedComponent);高阶函数的编写过程类似于这样 function higherOrderComponent(WrapperComponent) {return class NewComponent extends PureComponent {render() {return WrapperComponent/}} }组件的名称问题 在ES6中类表达式中类名是可以省略的所以可以可以写成下面的写法 function higherOrderComponent(WrapperComponent) {return class extends PureComponent {render() {return WrapperComponent/}} }另外组件的名称都可以通过displayName来修改 完整的代码我们可以这样来编写 import React, { PureComponent } from react;function higherOrderComponent(WrapperComponent) {return class NewComponent extends PureComponent {render() {return WrapperComponent/}} }class App extends PureComponent {render() {return (divApp/div)} }export default higherOrderComponent(App);高阶组件并不是React API的一部分它是基于React的组合特性而形成的设计模式 高阶组件在一些React第三方库中非常常见 比如redux中的connect比如react-router中的withRouter 在我们的开发中高阶组件可以帮助我们做哪些事情呢 1.2. 高阶组件的使用 1.2.1. props的增强 不修改原有代码的情况下添加新的props 假如我们有如下案例 class Header extends PureComponent {render() {const { name, age } this.props;return h2Header {name age}/h2} }export default class App extends PureComponent {render() {return (divHeader nameaaa age{18} //div)} }我们可以通过一个高阶组件让使用者在不破坏原有结构的情况下对某个组件增强props function enhanceProps(WrapperCpn, otherProps) {return props WrapperCpn {...props} {...otherProps} / }const EnhanceHeader enhanceProps(Header, {height: 1.88})有点拦截器和java动态代理的意思 利用高阶组件来共享 Context 属性 import React, { PureComponent, createContext } from react;const UserContext createContext({nickname: 默认,level: -1 })function Header(props) {return (UserContext.Consumer{value {const { nickname, level } value;return h2Header {昵称: nickname 等级 level}/h2}}/UserContext.Consumer) }function Footer(props) {return (UserContext.Consumer{value {const { nickname, level } value;return h2Footer {昵称: nickname 等级 level}/h2}}/UserContext.Consumer) }const EnhanceHeader enhanceProps(Header, { height: 1.88 })export default class App extends PureComponent {render() {return (divUserContext.Provider value{{ nickname: why, level: 90 }}Header /Footer //UserContext.Provider/div)} }利用高阶组件withUser import React, { PureComponent, createContext } from react;const UserContext createContext({nickname: 默认,level: -1 })function withUser(WrapperCpn) {return props {return (UserContext.Consumer{value {return WrapperCpn {...props} {...value}/}}/UserContext.Consumer)} }function Header(props) {const { nickname, level } props;return h2Header {昵称: nickname 等级: level}/h2 }function Footer(props) {const { nickname, level } props;return h2Footer {昵称: nickname 等级: level}/h2 }const UserHeader withUser(Header); const UserFooter withUser(Footer);export default class App extends PureComponent {render() {return (divUserContext.Provider value{{ nickname: why, level: 90 }}UserHeader /UserFooter //UserContext.Provider/div)} }1.2.2. 利用高阶组件进行鉴权判断 在开发中我们可能遇到这样的场景 某些页面是必须用户登录成功才能进行进入如果用户没有登录成功那么直接跳转到登录页面 这个时候我们就可以使用高阶组件来完成鉴权操作 function LoginPage() {return h2LoginPage/h2 }function CartPage() {return h2CartPage/h2 }export default class App extends PureComponent {render() {return (divCartPage//div)} }编写鉴权的高阶组件 function loginAuth(Page) {return props {if (props.isLogin) {return Page/} else {return LoginPage/}} }完整的代码如下 import React, { PureComponent } from react;function loginAuth(Page) {return props {if (props.isLogin) {return Page/} else {return LoginPage/}} }function LoginPage() {return h2LoginPage/h2 }function CartPage() {return h2CartPage/h2 }const AuthCartPage loginAuth(CartPage);export default class App extends PureComponent {render() {return (divAuthCartPage isLogin{true}//div)} }1.2.3. 生命周期劫持 import React, { PureComponent } from react;class Home extends PureComponent {UNSAFE_componentWillMount() {this.begin Date.now();}componentDidMount() {this.end Date.now();const interval this.end - this.begin;console.log(Home渲染使用时间:${interval})}render() {return (divh2Home/h2p我是home的元素,哈哈哈/p/div)} }class Detail extends PureComponent {UNSAFE_componentWillMount() {this.begin Date.now();}componentDidMount() {this.end Date.now();const interval this.end - this.begin;console.log(Detail渲染使用时间:${interval})}render() {return (divh2Detail/h2p我是detail的元素,哈哈哈/p/div)} }export default class App extends PureComponent {render() {return (divHome/Detail//div)} }我们可以定义如下高阶组件 function logRenderTime(WrapperCpn) {return class extends PureComponent {UNSAFE_componentWillMount() {this.begin Date.now();}componentDidMount() {this.end Date.now();const interval this.end - this.begin;console.log(Home渲染使用时间:${interval})}render() {return WrapperCpn {...this.props}/}} }const LogHome logRenderTime(Home); const LogDetail logRenderTime(Detail);完整代码如下 import React, { PureComponent } from react;function logRenderTime(WrapperCpn) {return class extends PureComponent {UNSAFE_componentWillMount() {this.begin Date.now();}componentDidMount() {this.end Date.now();const interval this.end - this.begin;console.log(${WrapperCpn.name}渲染使用时间:${interval})}render() {return WrapperCpn {...this.props}/}} }class Home extends PureComponent {render() {return (divh2Home/h2p我是home的元素,哈哈哈/p/div)} }class Detail extends PureComponent {render() {return (divh2Detail/h2p我是detail的元素,哈哈哈/p/div)} }const LogHome logRenderTime(Home); const LogDetail logRenderTime(Detail);export default class App extends PureComponent {render() {return (divLogHome /LogDetail //div)} }这个写法其实就是提取公共代码进行复用而已。 1.3. 高阶函数的意义 我们会发现利用高阶组件可以针对某些React代码进行更加优雅的处理。 其实早期的React有提供组件之间的一种复用方式是mixin目前已经不再建议使用 Mixin 可能会相互依赖相互耦合不利于代码维护不同的Mixin中的方法可能会相互冲突Mixin非常多时组件是可以感知到的甚至还要为其做相关处理这样会给代码造成滚雪球式的复杂性 当然HOC也有自己的一些缺陷 HOC需要在原组件上进行包裹或者嵌套如果大量使用HOC将会产生非常多的嵌套这让调试变得非常困难HOC可以劫持props在不遵守约定的情况下也可能造成冲突 Hooks的出现是开创性的它解决了很多React之前的存在的问题比如this指向问题、比如HOC的嵌套复杂度问题等等。
http://www.hkea.cn/news/14324247/

相关文章:

  • 学做网站需要多久时间珠海门户网站建设哪家专业
  • 沭阳做网站公司排名前十同时优化几个网站
  • 贵阳网站建设哪家便宜做百度手机网站排名
  • 建设网站平台的建议360优化大师官方最新
  • 青海省建设网站价格低百度投诉电话
  • 国外手机模板网站设计制作一个企业类型网站
  • 营销培训体系网站建设优化收费
  • 北京建设公司网站个人可以建门户网站吗
  • app软件开发就是网站开发吗品牌软文
  • 哈尔滨建设网站门户电商网站策划
  • 域名空间网站建设自己动手的网站
  • 带有响应式的网站装修设计软件哪个好用
  • 郑州专业网站设计的网站开发工具有哪些
  • 合肥营销型网站建设开发蒙特网设计公司
  • 如何免费注册网站平台网站ip需要备案
  • 什么网站可以做认证合肥微网站制作
  • 来雁新城建设投资公司官方网站成立公司需要哪些资料
  • 外包做一个网站一般多少钱北京新站优化
  • 如何做一元购网站宁波制作网页哪家好
  • 无锡高端网站建设咨询购物网站创业时是如何做宣传的
  • 做教案比较好的网站带商城的wordpress
  • 黄埔定制型网站建设烟台品牌网站建设
  • 一个平台网站开发wordpress媒体默认链接
  • 重庆网站建设模板制作优秀单页网站
  • 长沙市网站建设建设银行网站最近都打不开吗
  • 网站全景图怎么做wordpress出现不能登录
  • 2017民非单位年检那个网站做html5在网站建设中的
  • h5是什么网站上面做的网站的规划
  • 开源企业网站系统php网络公司 给 客户网站备案
  • 自已如何建网站wordpress的模板文件