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

JSX onClick 和 HTML onclick 的区别

在 JSX 中可以通过 onClick 这样的方式给一个元素添加一个事件处理函数,当然,在 HTML 中也可以用 onclick (小写 c),但在 HTML 中直接书写 onclick 一直就是为人垢病的写法...1、onclick 添加的事件处理函数是在全局环境下执行的,这污染了全局环境,很容易产生意料不到的后果; 2、给很多 DOM 元素添加 onclick 事件,可能会影响网页的性能,毕竟,网页需要的事件处理函数越多...: 既然长期以来一直不倡导在 HTML 中使用 onclick,为什么在 React 的 JSX 中我们却要使用 onClick 这样的方式来添加事件处理函数呢?...JSX onClick 和 HTML onclick 的区别 上面 HTML onclick 的这些问题,在 JSX 中都不存在,JSX 的 onClick 事件处理方式和 HTML 的 onclick...JSX 中的组件使用 onClick,并不会产生直接使用 onclick 的 HTML,而是使用了事件委托(event delegation)的方式处理点击事件,无论有多少个 onClick 出现,其实最后都只在

1.8K20

深入了解React.js的JSX1 JSX 与HTML2 JSX 和HTML 的不同之处

和React Native)。...但拥抱它会带来如下好处 XML 包含特性的元素树非常适合表示UI。 能够更精确和更方便地呈现应用程序的结构。 是普通JavaScript,并不会改变这门语言的语义。...React 的创造者只是让JSX 足够像HTML,这样就可以用来正确地描述Web 界面,并没有忽略这样一个事实,即它仍然应该遵循JavaScript 的风格和语法 2 JSX 和HTML 的不同之处 2.1...针对在使用JSX 构建组件时可能会遇到的常见问题,本节汇总了一些小技巧、提示和策略来供你应对。 单一根节点 React 组件只能渲染一个根节点。...尽管并无可能在JSX 中使用“if”语句,但仍有根据条件渲染内容的方法,包括使用三元表达式和将条件赋值给一个变量(空值和未定义的值都会被React 进行处理,JSX在转义时什么都不会输出)。

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

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

    在下节会详细介绍元素是如何被渲染出来的 先来看看 JSX 的基本使用方法 在 JSX 中使用表达式 可任意地在 JSX 当中使用 JavaScript 表达式,在 JSX 当中的表达式要包含在大括号里...的时候一般都会带上换行和缩进,这样可以增强代码的可读性 同样推荐在 JSX 代码的外面扩上一个小括号,这样可以防止 分号自动插入 的 bug JSX 本身其实也是一种表达式 在编译后,JSX 其实会被转化为普通的...针对在使用JSX 构建组件时可能会遇到的常见问题,本节汇总了一些小技巧、提示和策略来供你应对。 单一根节点 React 组件只能渲染一个根节点。...尽管并无可能在JSX 中使用“if”语句,但仍有根据条件渲染内容的方法,包括使用三元表达式和将条件赋值给一个变量(空值和未定义的值都会被React 进行处理,JSX在转义时什么都不会输出)。...简单地将条件语句移动到外部(就像你在第2 章中隐藏和显示ContactItem 细节时所采取的方法)。 下面是原先的代码: 1. render() { 2. return ( 3.

    2.4K30

    js中call和apply的区别

    调用函数时, call和apply传递参数的方式不同 以名为showHide的函数为例: function showHide(name1, name2){ if(this.parentNode.parentNode.querySelector...可以按照顺序传递showHide.call(this, '桐人', '亚丝娜') apply则是将参数放到一个数组, 统一传递showHide.apply(this, ['上条', '御坂']) 用call和apply...故事的主角上条当麻是学园里的一个无能力者,但并非完全没有能力,他的能力是能够将一切异能之力无效化。他只有右手能够使用这种能力,还给自己的这种连上帝的奇迹都能抹杀的能力取名为“幻想杀手”。...而正因为他的右手似乎把神的祝福都给抹杀掉的缘故,导致自己一直过著不幸的生活。... 小结: 使用call和apply调用函数时, 往往需要传递一个this, 目的是确定被调用函数showHide运行时函数内部this的指向, 以上面的demo为例, 如果调用函数

    1.8K30

    js typeof和instanceof 区别

    typeof一般是用来判断简单数据类型的,对一个值使用 typeof 操作符会返回下列字符串之一: “undefined”: 表示值未定义 “boolean”: 表示值为布尔值 “number”:...undefined" const variable2 = null; console.log(typeof variable2); // "object": 因为特殊值 null 被认为是一个对空对象的引用...[]); // "object" typeof ({}); // "object" typeof (new String("1")); // "object" 从上面的例子可以看到,typeof的弊端就是会把复杂数据类型都解释为..."object",所以对复杂数据类型的判断就不能用typeof。...instanceof 运算符用来测试一个对象在其原型链中是否存在一个构造函数的 prototype 属性,主要是用来判断复杂数据类型,返回布尔值,表示是否是某种类型(用于判断一个变量是否属于某个对象的实例

    1.6K20

    jquery和vue.js的区别

    1.jQuery首先要获取到dom对象,然后对dom对象进行进行值的修改等操作 2.Vue是首先把值和js对象进行绑定,然后修改js对象的值,Vue框架就会自动把dom的值就行更新。...3.可以简单的理解为Vue帮我们做了dom操作,我们以后用Vue就需要修改对象的值和做好元素和对 象的绑定,Vue这个框架就会自动帮我们做好dom的相关操作 4.这种dom元素跟随JS对象值的变化而变化叫做单向数据绑定...,如果JS对象的值也跟随着dom元素的值的变化而变化就叫做双向数据绑定 简单来说,最明显的就是思维方式不同,jquery 是以操作dom为主,做了数据处理之后还需要对dom进行操作。...vue.js是以操作数据为主,不操作dom,也就是传说中的双向数据绑定,你只需要操作数据就好,dom自动更新。这只是对初学者来说最大的不同。...jquery只是一个类库,只是提供了很多的方法,不能算框架,而vue.js是一个框架,有一套完整的体系。所以jquery自然不能和vue比。

    1.5K20

    js forEach和 map 区别

    forEach() 方法按升序为数组中含有效值的每一项执行一次 callbackFn 函数,那些已删除或者未初始化的项将被跳过(例如在稀疏数组上,见下方的示例)。...调用 forEach 后添加到数组中的项不会被 callbackFn 访问到。 如果已经存在的值被改变,则传递给 callbackFn 的值是 forEach() 遍历到他们那一刻的值。...() map() 方法创建一个新数组,这个新数组由原数组中的每个元素都调用一次提供的函数后的返回值组成。...调用 map 方法之后追加的数组元素不会被 callbackFn 访问。如果存在的数组元素改变了,那么传给 callbackFn 的值是 map 访问该元素时的值。...根据规范中定义的算法,如果被 map 调用的数组是离散的,新数组将也是离散的保持相同的索引为空。 map因为返回数组所以可以链式操作,forEach不能

    4.6K30
    领券