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

源码做微信电影网站中山谷歌推广

源码做微信电影网站,中山谷歌推广,日本做牛仔裤视频网站,网站开发学校 优帮云为什么要用 JSX? JSX 给 HTML 赋予了 JS 的编程能力 JSX 的本质 JSX 是 JavaScript 的语法扩展,浏览器本身不能识别,需要通过解析工具(如babel)解析之后才能在浏览器中运行。 bable 官网可以查看解析过程 JSX 的语法 …

为什么要用 JSX?

JSX 给 HTML 赋予了 JS 的编程能力

JSX 的本质

JSX 是 JavaScript 的语法扩展,浏览器本身不能识别,需要通过解析工具(如babel)解析之后才能在浏览器中运行。

bable 官网可以查看解析过程

在这里插入图片描述

JSX 的语法

{} 中写 JS 表达式

类似 vue 的 {{}}

渲染 JS 数据

对象

<div style={{ color: "red" }}>朝阳</div>

其他类型的数据也能直接渲染,但基本不会使用。

渲染变量

function Demo() {const name = "朝阳";return (<><div>{name}</div></>);
}export default Demo;

调用函数

function getName() {return "朝阳";
}function Demo() {return (<><div>{getName()}</div></>);
}export default Demo;

调用方法

<div>{new Date().getDay()}</div>

添加注释

{/* 我是一段注释 */}

条件渲染 if

类似 vue 的 v-if

单分支 ( && )

function Demo() {const showName = true;return <>{showName && <div>朝阳</div>}</>;
}

双分支( 三元运算符 ?: )

function Demo() {const login = false;return <>{login ? <div>朝阳</div> : <button>登录</button>}</>;
}

多分支( 调用内含 if 的函数 )

单分支和双分支也能使用,只是麻烦了些。

const type = "2";function getTypeName() {if (type === "1") {return <div>生活</div>;} else if (type === "2") {return <div>学习</div>;} else if (type === "3") {return <div>工作</div>;}
}function Demo() {return <>{getTypeName()}</>;
}export default Demo;

若分支特别多,也可以使用 Switch 语句。

const type = "3";function getTypeName() {switch (type) {case "1":return <div>生活</div>;case "2":return <div>学习</div>;case "3":return <div>工作</div>;default:break;}
}function Demo() {return <>{getTypeName()}</>;
}export default Demo;

列表渲染 map

类似 vue 的 v-for

  • 必须设置独一无二的 key,且不能是 index 和随机数,通常用 id
  • key 能提升 react 更新渲染的性能
  • map 内箭头函数的返回值用 () 包裹
function Demo() {const list = [{id: 1,name: "朝阳",},{id: 2,name: "晚霞",},];return (<><ul>{list.map((item) => (<li key={item.id}>{item.name}</li>))}</ul></>);
}export default Demo;
  • 朝阳
  • 晚霞

绑定事件

类似 vue 的 v-on (简写@)

  • 以 on 开头,接首字母大写的事件名,如点击事件 onClick
function Demo() {function hello() {alert("你好");}return (<><button onClick={hello}>问好</button></>);
}export default Demo;

获取事件对象 e

  • 此处的e 是一个React 定义的已解决了跨浏览器的兼容性问题的合成事件。(vue中是原生事件)
  • 通过 e.nativeEvent 可获取原生事件
function Demo() {function hello(e) {console.log(e);}return (<><button onClick={hello}>问好</button></>);
}

自定义事件传参

需使用箭头函数,否则便是调用函数,会在页面加载时立马执行。

function Demo() {function hello(name) {alert("你好," + name);}return (<><button onClick={() => hello("朝阳")}>问好</button></>);
}export default Demo;

此时要想获取事件对象 e,需在箭头函数传入参数e

function Demo() {function hello(name, e) {console.log("你好," + name);console.log(e);}return (<><button onClick={(e) => hello("朝阳", e)}>问好</button></>);
}export default Demo;

添加样式

行内样式【不推荐】

<div style={{ color: "red" }}>你好</div>

类样式

  • 样式写在单独的(如与组件同名的)css 文件中
  • 通过 import 导入样式
  • 通过 className 属性添加样式,注意,不是 class

src\Demo.css

.red {color: red;
}

src\Demo.jsx

import "./Demo.css";const Demo = () => {return <div className="red">你好</div>;
};export default Demo;
http://www.wangmingla.cn/news/163972.html

相关文章:

  • b2c电子商务网站解决方案今日国际重大新闻事件
  • 专门做旅游的视频网站如何推广外贸型网站
  • wordpress评论框代码网站优化seo方案
  • 用ps做网站网页注册一个公司网站需要多少钱
  • 余姚做网站设计哪个搜索引擎能搜敏感内容
  • 中华人民共和国城乡与建设部网站浏览器网站进入口
  • 自己建的网站百度查找不到seo在线培训机构排名
  • 信息型网站有哪些获客引流100种方法
  • 公司网站自己可做吗宣传广告怎么做吸引人
  • 网页设计教程电商南京市网站seo整站优化
  • 哪个网站做兼职seo渠道是什么意思
  • 如何选择大连网站建设经典广告推广词
  • 做汽配网站近期重大新闻事件10条
  • 网站建设找推推蛙重庆网站网络推广
  • 钟楼做网站dy刷粉网站推广马上刷
  • 做网站的技术支持seo推广排名软件
  • 不会代码怎么做网站天津seo
  • 品牌网站建设特色大蝌蚪百度推广代运营
  • 上海到北京飞机票多少钱朝阳区seo
  • php 建设网站制作百度百科优化排名
  • 广州开发网站宁波seo推广哪家好
  • html网页制作方法seo资料
  • 网站建设谈判邵阳网站seo
  • 301重定向到新网站色盲
  • 七牛云如何做网站缓存网站优化方案
  • 长沙 网站seo服务 网络服务推广方法
  • 网站上传图片要求接单平台app
  • 宁波外贸公司大全西安新站网站推广优化
  • 还能电子商务网站建设什么平台发广告最有效
  • 网站开发哈尔滨网站开发公司郑州网络营销与网站推广