ReactNative进阶(六):ReactNative语法学习及常见问题汇总

一、基础知识

1.1 {} 与 ()

对于第一次接触ReactNative的同学,最痛苦的是什么时候使用{},什么时候使用(),当然我也经历过那段时间,为此简单总结了下。

  • ReactNative中,使用表达式的时候需要用{}包住;
css 复制代码
style={styles.mainStyle}
  • ReactNative中,在字符串中使用变量的时候,需要用{}包住;
java 复制代码
var str = 'hello'
<Text>{str}</Text>
  • ReactNative中,对象,字典需要用{}包住;
java 复制代码
style = {}, // 最外层表达式,用{}包住
{flex:1}, // 对象,用{}包住
<View style={{flex:1}}></View>
  • 创建组件<View></View>,必须要用()包住; 因此只要返回组件,都需要用()
java 复制代码
render(){
    return (
        <View style={styles.mainStyle}>
        </View>
    )
}

1.2 注释

HTML标签节点内,使用{/* */}进行注释;HTML标签节点外,多行可以用/**/进行注释,单行可以用//进行注释。

使用 // 作为注释要注意,注释内容必须不在任何 html 标签里,否则会当成要显示的文本内容。

二、常见问题

2.1 How to resolve "EADDRINUSE: address already in use" error(8081端口被占用了)

Error: listen EADDRINUSE: address already in use :::8081 at Server.setupListenHandle [as _listen2] (net.js:1258:14) at listenInCluster (net.js:1306:12) at Server.listen (net.js:1394:7)

解决办法:

javascript 复制代码
lsof -i TCP:8081 | grep LISTEN

会出现如下类似提示:

javascript 复制代码
node    2464 murari   21u  IPv6 4392639      0t0  TCP *:http-alt

然后执行:

javascript 复制代码
kill -9 2464

2.2 Android error "Could not get BatchedBridge, make sure your bundle is packaged properly" on start of app

shell 复制代码
react-native run-android
react-native start --reset-cache

三、延伸阅读

在学习一门新语言,搭建完新项目时,有必要了解下项目结构。

HelloWorld > |-- android > |-- ios > |-- node_modules > |-- package.json > |-- index.js

> |-- img > |-- public > |-- scene > |-- libs

android:Android原生工程目录;

ios:IOS原生工程目录;

package.jsonReact Native是基于javasript开发的语言,使用npm做为包管理工具,这个文件就是npm的包管理文件,主要配置项目依赖的第三方包;

index.js:这个文件是IOSAndroid在相应设备上打包运行的入口文件;(备注:早期React Native项目应该是index.ios.jsindex.android.js两个单独的入口文件)

img:存放界面要显示的png图片;

public:存放工具js,网络请求js的封装,数据存储js等相关操作的js;(备注:可以在public中创建分类目录,public/net、public/datastorage等)

scene:存放项目的JS组件(界面);(备注:可以在scene目录下创建不同功能模块的目录,例如scene/draw,scene/user,scene/home等二级三级目录)

四、拓展阅读

相关推荐
脾气有点小暴3 分钟前
CSS position 属性
前端·css
ohyeah22 分钟前
用原生 JS 手写一个“就地编辑”组件:EditInPlace 的 OOP 实践
前端·javascript
timeweaver30 分钟前
React Server Components 的致命漏洞CVE-2025-55182
前端·安全
重铸码农荣光31 分钟前
深入理解 JavaScript 中的 this:一场关于作用域、调用方式与设计哲学的思辨
前端·javascript
新晨43732 分钟前
跨域是服务器拒绝请求还是浏览器去拒绝的请求?
前端·浏览器
珑墨37 分钟前
【包管理器】pnpm、npm、cnpm、yarn 深度对比
前端·javascript·npm·node.js
草字1 小时前
uniapp 滚动到表单的某个位置,表单验证失败时。
前端·javascript·uni-app
学到头秃的suhian1 小时前
Spring使用三级缓存解决循环依赖问题
前端·spring·缓存
CXH7281 小时前
架构师的登山之路|第十二站:服务网格 Istio——未来的标配,还是复杂过头?
前端·javascript·istio
脾气有点小暴1 小时前
详解 HTML Image 的 mode 属性:图像显示模式的灵活控制
前端·html·uniapp