react 学习笔记 使用 jsx 语法

react 学习笔记

使用 jsx 语法

  • 概念

const element = <h1>hello world!</h1>;

<font color="red">JSX</font>是一种 JavaScript 的语法拓展。我们推荐 react 中使用 jsx 来描述用户界面。<font color="red">JSX</font>看起来可能比较像模板语法,但事实上它完全是 JavaScript 内部实现的。

React 通过 jsx 快速的渲染 DOM 节点,但我们开始说说<font color="red">JSX</font>语法必备的一些基本知识

这里着重声明,所谓的 JSX 一定是以标签为开端,以标签为终结的语句即为 JSX,在 React 编译这段 JSX 时,会将它处理为一个 JavaScript 对象。同时 React 语法是基于 ES6 的

  • 在 JSX 中可以掺杂表达式

    如何插入呢,我们需要将 JXS 表达式都用一个大括号包括进来。

    而所谓的表达式即 JavaScript 中的表达式,比如:<font color="red">1+1</font>,<font color="red">user.id</font>,和<font color="red">func(a,b)</font>等,综合如为下:
  1. 变量名
  2. JSX 语法表达式(也就是说 JSX 其实是一种表达式)
  3. 自执行函数表达式(如果只是单纯的函数定义的表达也可以,只是没有运行结果)
  4. 函数调用表达式
  5. 属性访问表达式
  6. 算法,关系,逻辑,字符串表达式
  7. 三元运算表达式

示例如下:

//变量
const use = "abc";
//属性表达式
const user = {
  fristName:"yang",
  lastName:"gg"
};
//函数调用表达式
function formatName(user){
  return `${user.fristName} ${user.lastName}`
}
const t1 = 1; const t2 = 2;
//JSX
const a = <div>{use}</div>
const b = <div>{user.fristName}</div>
const c = <div>formatName(user)</div>
const d = <div>{1+1+1}</div>
const e = <div>{t1 && t2}</div>
const f = <div>{t1 < t2 ? "t1小于t2": "333"}</div>
const i = <div>{function(){return "自调函数"}()}</div>
const k = {<div>iii</div>}

说的通透点,在JSX中可以插入的就是函数调用,和我们的标识符,还有运算。

多说一句就是,如果存在多行JSX语句要写,我们可以进行如下处理

const a = (
  <div>
    <h1>a</h1>
  </div>
)

需要用小括号括起来

  • JSX语法是一个对象,是一个运用HTML标签结构却实现了JavaScript语法对象。

前面也强调了JSX语句其本质就是一个JavaScript对象和表达式,最简单的例子证明就是如下:

function getGreeting(user){
  if(user){
    return <h1>hello,{formatName(user)}</h1>
  }
  return <h1>Hello,Stranger.</h1>
}

它可以在函数中直接返回,所谓返回值,那他一定是一个值,不是对象就是基础数据类型.

这里想让大家升入一个观念,JSX不是HTML标签

那么问题来了,JSX竟然类似于HTML标签,那么它虽然不是HTML标签,但是是否拥有HTML标签的一些特性,它可以自定义属性吗,当然可以,但是这里需要注意一下几点:

  • 对于一个HTML标签已经拥有的属性,jsx需要用驼峰命名来处理,比如tabindex必须写成tabIndex 才能起作用,比如:
const el = <div tabIndex="0"></div>;

当然对于class会出现问题,因为在ES6下可以用<font color="red">class</font>定义类出现在JSX中。

const el = <div className="temp"></div> //true
const el2 = <div class="temp"></div> //false
  • **对于用户的自定义属性(肯定可以自定义),当然我们必须要叫<font color="red">data-</font>前缀,否则无效。
const el = <div fff="0"></div> //false
const el2 = <div data-fff="0"></div>//true
  • 对于属性的赋值会有限制
    有两种赋值方法:

    ① 使用大括号(就是我们用的表达式赋值)
    ② 是使用双引号赋值
const el = <div className={'abc'}></div> //①
const el2 = <div className="abc"></div> //②
  • jsx语法的安全性

jsx的好处:

  1. Javascript中使用类似HTML的语法
  2. 可以有效的防止xss注入
  3. 它可以快速的编写一个UI组件
  • JSX语句是怎么编译的

const el = (
  <div className="greeting">hello, world</div>
)

对于上面这个JSX语句,react编译处理形成如下的对象:

const element = React.creatElement('div',{className:'greeting'},'hello , word')

每一个参数对应起来**[标签名,属性,孩子节点]

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,367评论 6 512
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,959评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,750评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,226评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,252评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,975评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,592评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,497评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,027评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,147评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,274评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,953评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,623评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,143评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,260评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,607评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,271评论 2 358

推荐阅读更多精彩内容

  • 以下内容是我在学习和研究React时,对React的特性、重点和注意事项的提取、精练和总结,可以做为React特性...
    科研者阅读 8,239评论 2 21
  • 本笔记基于React官方文档,当前React版本号为15.4.0。 1. 安装 1.1 尝试 开始之前可以先去co...
    Awey阅读 7,722评论 14 128
  • react 基本概念解析 react 的组件声明周期 react 高阶组件,context, redux 等高级...
    南航阅读 1,069评论 0 1
  • 深入JSX date:20170412笔记原文其实JSX是React.createElement(componen...
    gaoer1938阅读 8,070评论 2 35
  • 0:51 我回到了北京的家中,带着满满的正能量和昂扬的斗志准备踏上新的征途。高三将会是辛苦的一年,我将这次台湾之行...
    初棠阅读 374评论 0 2