我的编程空间,编程开发者的网络收藏夹
学习永远不晚

es6怎么解决因React Native出现的问题

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

es6怎么解决因React Native出现的问题

这篇文章主要介绍“es6怎么解决因React Native出现的问题”,在日常操作中,相信很多人在es6怎么解决因React Native出现的问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”es6怎么解决因React Native出现的问题”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

构造函数

定义侦探类作为例子。

ES5的“类”是如何定义的。

function ES5Detective() {   console.log('##ES5Detective contructor'); }

ES6定义类:

class ES6Detective {   constructor() {     console.log('Detective constructor');   } }

ES6使用了class关键字,而且有专门的constructor。ES5里的function ES5Detective既是类的定义,也是构造函数。

属性

看看这个侦探是从哪本书出来的。

ES5:

ES5Detective.prototype.fromBookName = 'who';

ES6:

class ES6Detective {   detectiveName: string;   _bookName: string;    constructor() {     console.log('Detective constructor');     this.detectiveName = 'Detective who'; // 属性   } }

ES6 getter & setter

class ES6Detective {   detectiveName: string;   _bookName: string;    constructor() {     console.log('Detective constructor');     this.detectiveName = 'Detective who';     this._bookName = 'who';   }    get fromBookName() {     return this._bookName;   }    set fromBookName(value) {     this._bookName = value;   } }

如果只有getter没有setter而赋值的话就会出现下面的错误:

detective.bookAuthor = 'A C';                      ^  TypeError: Cannot set property bookAuthor of #<ES6Detective> which has only a getter

实例方法

侦探是如何解决案件的。

ES5:

ES5Detective.prototype.solveCase = function(caseName) {   var dn = this.dectiveName;   if(!caseName) {     console.log('SOLVE CASE: ' + dn + ' no case to solve');   } else {     console.log('SOLVE CASE: ' + dn + ' get case ' + caseName + ' is solved');   } };

或者:

function ES5Detective() {   this.dectiveName = 'Detective who';   console.log('##ES5Detective contructor');   // 实例方法   this.investigate = function(scene) {     console.log('investigate ' + scene);   }    this.assistant = "assistant who"; }

ES6:

class ES6Detective {   detectiveName: string;   _bookName: string;    constructor() {     console.log('Detective constructor');     this.detectiveName = 'Detective who';     this._bookName = 'who';   }    solveCase(caseName) {     if(!caseName) {       console.log('no case to solve');     } else {       console.log('case ' + caseName + ' is solved');     }   } }

ES6添加方法非常简单直接。ES5中添加实例方法有两种方法,一是在prototype里定义,一是在构造函数重定义。在构造函数中定义的实例方法和属性在每一个实例中都会保留一份,而在原型中定义的实例方法和属性是全部实例只有一份。

另外,在ES5的构造函数重定义的实例方法可以访问类的私有变量。比如:

function ES5Detective() {   console.log('##ES5Detective contructor');    var available: boolean = true; // private field. default income is ZERO.   this.investigate = function(scene) {     if (available) {       console.log('investigate ' + scene);     } else {       console.log(`i'm not available`);     }   } }

在其他的方法访问的时候就会报错。

if (!available) {  ^

静态方法

ES5:

ES5Detective.countCases = function(count) {   if(!count) {     console.log('no case solved');   } else {     console.log(`${count} cases are solved`);   } };

类名后直接定义方法,这个方法就是静态方法。

ES5Detective.countCases();

ES6:

class ES6Detective {   static countCases() {     console.log(`Counting cases...`);   } }  // call it ES6Detective.countCases();

继承

ES6使用extends关键字实现继承。

ES5:

function ES5Detective() {   var available: boolean = true; // private field.    this.dectiveName = 'Detective who';   console.log('##ES5Detective contructor');    this.investigate = function(scene) {     // 略    }    this.assistant = "assistant who"; }  ES5Detective.prototype.solveCase = function(caseName) {   // 略 }  // inheritance function ES5DetectiveConan() {   // first line in constructor method is a must!!!   ES5Detective.call(this);    this.dectiveName = 'Conan'; }  // inheritance ES5DetectiveConan.prototype = Object.create(ES5Detective.prototype); ES5DetectiveConan.prototype.constructor = ES5DetectiveConan;

ES5继承的时候需要注意两个地方:

  1. 需要在子类的构造函数里调用SuperClass.call(this[, arg1, arg2, ...])

  2. 子类的prototype赋值为:SubClass.prototype =  Object.create(SuperClass.prototype),然后把构造函数重新指向自己的:SubClass.prototpye.constructor  = SubClass。

ES6:

class ES6Detective {   constructor() {     console.log('Detective constructor');     this.detectiveName = 'Detective who';     this._bookName = 'who';   }    solveCase(caseName) {     if(!caseName) {       console.log('no case to solve');     } else {       console.log('case ' + caseName + ' is solved');     }   }    get fromBookName() {     return this._bookName;   }    set fromBookName(value) {     this._bookName = value;   }    get bookAuthor() {     return 'Author Who';   }    static countCases() {     console.log(`Counting cases...`);   } }  class ES6DetectiveConan extends ES6Detective {   constructor() {     super();     console.log('ES6DetectiveConan constructor');   } }

ES6的新语法更加易懂。

注意:一定要在子类的构造方法里调用super()方法。否则报错。

调用super类内容

class ES6DetectiveConan extends ES6Detective {   constructor() {     super();     console.log('ES6DetectiveConan constructor');   }    solveCase(caseName) {     super.solveCase(caseName);      if(!caseName) {       console.log('CONAN no case to solve');     } else {       console.log('CONAN case ' + caseName + ' is solved');     }   } }

静态方法可以被继承

ES6的静态方法可以被继承。ES5的不可以。

class ES6Detective {   static countCases(place) {     let p = !place ? '[maybe]' : place;     console.log(`Counting cases...solve in ${p}`);   } }  class ES6DetectiveConan extends ES6Detective {   constructor() {     super();     console.log('ES6DetectiveConan constructor');   } }  // static method ES6Detective.countCases(); ES6DetectiveConan.countCases('Japan');  // result Counting cases...solve in [maybe] Counting cases...solve in Japan

在子类ES6DetectiveConan并没有定义任何方法,包括静态方法。但是,在父类和子类里都可以调用该方法。

甚至,可以在子类里调用父类的静态方法:

class ES6DetectiveConan extends ES6Detective {   static countCases(place) {     let p = !place ? '[maybe]' : place;     super.countCases(p);     console.log(`#Sub class:- Counting cases...solve in ${p}`);   } }  // result Counting cases...solve in [maybe] Counting cases...solve in Japan #Sub class:- Counting cases...solve in Japan

到此,关于“es6怎么解决因React Native出现的问题”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

es6怎么解决因React Native出现的问题

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

React Native断点调试跨域资源加载出错问题的原因分析

React Native 是一种用于构建移动应用的框架,它使用的是 JavaScript 和 React 的语法。在使用 React Native 进行开发时,有时可能会遇到跨域资源加载出错的问题,导致断点调试无法正常进行。下面是可能导致此
2023-09-01

React Native断点调试 跨域资源加载出错问题的原因分析

React Native断点调试时遇到跨域资源加载出错的问题可能有以下几个原因:1. 网络请求配置问题:React Native的网络请求使用的是XMLHttpRequest或Fetch API,跨域资源加载出错可能是因为请求的URL不在允
2023-09-23

React Native:真机断点调试+跨域资源加载出错问题解决

在React Native开发中,有时候我们需要在真机上进行断点调试来定位问题。本文将介绍如何在真机上进行断点调试,并解决跨域资源加载出错的问题。1. 首先,我们需要将真机连接到开发机器上。确保真机和开发机器在同一个局域网中,并且已经安装了
2023-09-06

react跨域问题怎么解决

在 React 中解决跨域问题通常有以下几种方法:1. 设置代理:在开发环境中,可以通过设置代理服务器来解决跨域问题。可以在 `package.json` 文件中的 `proxy` 字段中添加代理服务器的地址,例如:```"proxy":
2023-08-19

win10出现config.msi问题怎么解决

要解决Windows 10中的config.msi问题,可以尝试以下方法:重命名config.msi文件夹:首先,打开资源管理器,导航到C:\根目录下找到config.msi文件夹(如果找不到,可能是因为该文件夹被隐藏了,需要显示隐藏文件)
win10出现config.msi问题怎么解决
2024-02-29

怎么解决React中的re-render问题

这篇文章主要介绍“怎么解决React中的re-render问题”,在日常操作中,相信很多人在怎么解决React中的re-render问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么解决React中的re
2023-06-29

win7 Ubuntu Grub出现问题怎么解决

这期内容当中小编将会给大家带来有关win7 Ubuntu Grub出现问题怎么解决,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。重启,直接进入install Ubuntu,然后安装成功了。再重启。然后悲剧
2023-06-16

react usestate异步问题怎么解决

在React中,useState钩子是同步的,它不会自动处理异步操作。因此,当遇到需要在useState之后执行异步操作的情况时,可以采用以下方法解决:1. 使用useEffect钩子:可以在useEffect中执行异步操作,并在异步操作完
2023-10-07

使用jBuilder8出现问题怎么解决

如果您在使用jBuilder8时遇到问题,可以尝试以下解决方案:确保您的操作系统和Java版本与jBuilder8的要求兼容。查看jBuilder8的官方文档或网站,了解最低要求和兼容性信息。检查您的jBuilder8安装是否正确。如果您是
使用jBuilder8出现问题怎么解决
2023-10-28

win11内核出现问题怎么解决

本篇内容主要讲解“win11内核出现问题怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“win11内核出现问题怎么解决”吧!方法一:1、首先点开底部“开始菜单”2、然后在顶部搜索并打开“v
2023-07-02

navicat激活出现问题怎么解决

navicat 激活问题解决方案:检查许可证密钥的正确性。确保 navicat 版本与许可证密钥匹配。重新安装 navicat 并删除指定文件夹。禁用防火墙和防病毒软件。若仍无法解决问题,请联系 navicat 支持团队。Navicat 激
navicat激活出现问题怎么解决
2024-04-06

vue中出现function () { [native code] }错误怎么解决

本篇内容主要讲解“vue中出现function () { [native code] }错误怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue中出现function () { [nat
2023-06-29

vue3使用socket.io的出现的问题怎么解决

今天小编给大家分享一下vue3使用socket.io的出现的问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。问题一
2023-07-05

解决AndroidStudio出现“Cannotresolvesymbol”的问题

今天在调试的时候,AndroidStudio报了一个莫名其妙的错误Cannotresolvesymbol'R'让人不知所措,因为这东西根本不归我管啊,怎么会出现Cannotresolvesymbol这种错误呢?下面给大家分享AndroidStudio出现“Cannotresolvesymbol”解决方案,需要的朋友可以参考下
2023-03-13

react异步渲染问题怎么解决

在React中,可以使用异步渲染来优化性能并提升用户体验。有几种方式可以解决React异步渲染问题:1. 使用React.lazy和Suspense:React.lazy函数可以让你像渲染常规组件一样渲染动态导入的组件。Suspense组件
2023-08-19

编程热搜

目录