首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

React中JSX的理解

描述 JSX发展过程 在之前,Facebook是PHP大户,所以React最开始的灵感就来自于PHP。 在2004年这个时候,大家都还在用PHP的字符串拼接来开发网站。...JSX会被babel转换成React.createElement的函数调用,调用后会创建一个描述HTML信息的Js对象。 JSX中的子元素可以为字符串字面量。 JSX中的子元素可以为JSX元素。...JSX的使用 在示例中我们声明了一个名为name的变量,然后在JSX中使用它,并将它包裹在大括号中。在JSX语法中,可以在大括号内放置任何有效的JavaScript表达式。...也就是说,你可以在if语句和for循环的代码块中使用JSX,将JSX赋值给变量,把JSX当作参数传入,以及从函数中返回JSX。...; } 通常可以通过使用引号来将属性值指定为字符串字面量,也可以使用大括号来在属性值中插入一个JavaScript表达式,在属性中嵌入JavaScript表达式时,不要在大括号外面加上引号。

2.5K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    React Native 中的JSX学习

    JSX是什么 字面上来看JSX即 JavaScript XML取首字母结合,所以JSX并不是一门新语言,仅仅是个语法糖。 React发明了JSX,利用HTML语法来创建虚拟DOM。...2☞增强JS语义 3☞结构清晰 4☞抽象程度高 5☞代码模块化 JSX在React Native  该文章主要介绍JSX在React Native 中的实际使用,没有详细介绍JSX语法。...1.JSX 中嵌入变量,表达式,样式    这段Demo在标签里嵌入了变量,表达式和样式两种写法 var testName = 'zzy'; render() { return(...语法可以当做加强版的JS,在React中使用,依赖Babel编译。  ...JSX最明显的特点就是可以在JS中写标签,并不用加引号,在标签里使用JS变量也十分方便 ,在标签里当遇到{}当做JS解析。  JSX在ReactNative还有很多特点,今后慢慢的探究,学习消化。

    2.5K20

    React.js 实战之 JSX 简介在 JSX 中使用表达式JSX 本身其实也是一种表达式JSX 属性JSX 嵌套JSX 防注入攻击JSX 代表 ObjectsJSX 的怪异之处

    ; 这种看起来可能有些奇怪的标签语法既不是字符串也不是 HTML 它被称为 JSX, 一种 JavaScript 的语法扩展 推荐在 React 中使用 JSX 来描述用户界面 JSX...JSX 嵌套 若 JSX 标签是闭合式的,需在结尾处用/>, 就好像 XML/HTML 一样 JSX 标签同样可以相互嵌套 警告: 因为 JSX 的特性更接近 JavaScript 而不是 HTML...所有的内容在渲染之前都被转换成了字符串。...解决的方法非常简单:就像你在普通JavaScript 中会做的那样,将所有返回值包含到一个根对象中。...尽管并无可能在JSX 中使用“if”语句,但仍有根据条件渲染内容的方法,包括使用三元表达式和将条件赋值给一个变量(空值和未定义的值都会被React 进行处理,JSX在转义时什么都不会输出)。

    2.4K30

    在Vue 3中使用JSX

    每当讲到 template 和 JSX,可能就会讨论到一个比较大的问题,React 和 Vue 哪个好。...在 Vue 2 中,JSX 的编译需要依赖 @vue/babel-preset-jsx 和 @vue/babel-helper-vue-jsx-merge-props 这两个包。...在 Vue 3 中,只要安装一个 Babel 插件就完事了,可以理解为不再需要额外的第三方库,源码中就有 jsx.d.ts[5] 用来支持 JSX 的类型检查 ? 6....适合用在结果比较复杂,组件内容可以复用的地方,简单来说就是在组件中可以预留空间,从父级把内容给传进去。在 JSX 中,父组件给子组件来传递 VNode 通过属性来传递就完事了。...在这个例子里面,用模板写的代码 比用 JSX 写的要快十几毫秒。在实际的场景中,组件的层级嵌套远比这里给出的 demo 要复杂,这个时候就更加能够体现模板的优势了。

    2K30

    React基础(3)-不可不知的JSX

    react学习(3)-不可不知的JSX.png 前言 本篇内容,对上一节的补充 JSX中添加属性有什么要注意的?以及JSX中的子元素是怎么操作的?...子元素嵌套** 在React中,子元素允许由多个JSX元素组成,组件可以嵌套组件,例如:如下所示 <...代码作用域内 引入React库一部分目的就是为了识别JSX语法的,这也是为什么只要你定义一个React组件时,要引入React库的原因 使用点(.)语法 有时候,在一个模块中需要导出多个React组件时...,在JSX中,使用点语法来引用一个React组件就非常方便了的 例如:如下所示 import React, { Fragment, Component } from 'react'; import...中添加属性的命名方式应是camelCase驼峰式命名来定义属性的名称,JSX中的子元素可以是字符串,可以嵌套,以及js表达式,函数都可以作为子元素 并且在React中组件的定义以及调用处,组件名称首字母必须要大写

    1.8K10

    React学习(三)-不可不知的JSX

    那么读完本文,就豁然开朗了 JSX添加特定属性 自定义标签拓展了原生HTML标签不具备的能力,最大的一个用处就是属性传值,标签的属性值,可以是字符串,变量对象 例如:如下所示 const element...子元素嵌套 在React中,子元素允许由多个JSX元素组成,组件可以嵌套组件,例如:如下所示 ...函数作为子元素 {}插值表达式内可以可以变量,字符串,普通HTML元素,甚至可以是组件,还可以是函数 import React from 'react'; import ReactDOM from '...库一部分目的就是为了识别JSX语法的,这也是为什么只要你定义一个React组件时,要引入React库的原因 使用点(.)语法 有时候,在一个模块中需要导出多个React组件时,在JSX中,使用点语法来引用一个...结语 本文主要讲述在JSX中添加属性的命名方式应是camelCase驼峰式命名来定义属性的名称,JSX中的子元素可以是字符串,可以嵌套,以及js表达式,函数都可以作为子元素 并且在React中组件的定义以及调用处

    1.3K30

    在 TypeScript 中始终抽象嵌套类型

    在 TypeScript 中,我看到过多次出现这种情况,您有一个复杂的对象,该对象可能具有嵌套对象,例如下面的示例:interface ComplexObject { a: string; b: number...现在假设我们想要编写一个以该对象作为输入的函数,可能会进行一些插值,并且可能会返回该对象的子对象,例如嵌套属性,您可能会有以下代码:const printObj = (obj: ComplexObject...处理类似上面的复杂对象的更好方法是将所有嵌套属性抽象为它们自己的接口/类型。...IntelliSense 检查相同的函数,您将获得更加易读的输出:const printObj: (obj: ComplexObject) => ComplexObjectNested您还可以添加一个优点,即您还可以将嵌套接口用于其他目的

    16400

    AntDesign-React与VUE有点不一样,第一篇深入了解React的概念之一:JSX

    AntDesign-React与VUE有点不一样,第一篇深入了解React的概念之一:JSX 一、什么是JSX 使用JSX声明一个变量(REACT当中的元素): const element =Hello...JSX 会将引号当中的内容识别为字符串而不是表达式。...所有的内容在渲染之前都被转换成了字符串。这样可以有效的防止XSS(跨站脚本)攻击。 九、HTMl转义 REACT会将所有要显示到DOM的字符串转义,防止XSS。...所以如果JSX中包含转义后的实体字符串比如©:(©)最后显示到DOM中不会被正确显示,因此REACT自动吧©中的特殊字符转义了。...); React. createElement()这个方法首先会进行一些避免BUG的检查,之后返回一个类似下面例子的对象: // 注意: 以下示例是简化过的(不代表在 React 源码中是这样) const

    93810

    React基础篇 - 02.JSX 简介

    JSX 简介 请观察下面的变量声明: const element = Hello, world!; 这种看起来可能有些奇怪的标签语法既不是字符串也不是HTML。...这也就意味着,你其实可以在 if 或者 for 语句里使用 JSX,将它赋值给变量,当作参数传入,作为返回值都可以: function getGreeting(user) { if (user) {...= {title}; 默认情况下,React DOM 在渲染前会 转义 嵌入在 JSX 中的任何值。...所有的内容在渲染之前都被转换成了字符串。这样可以有效地防止 XSS(跨站脚本) 攻击。...); React.createElement() 这个方法首先会执行一些检查,以帮助您编写无错误的代码,之后会返回一个类似下面的对象: // 注意: 以下示例是简化过的(不代表在 React 源码中是这样

    89950
    领券