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

建立网站如何规划和实施建设网络营销和推广的方法

建立网站如何规划和实施建设,网络营销和推广的方法,聊城网站设计公司,菏泽网站建设公司有哪些往期回顾:# React基础入门之虚拟Dom【一】 面向组件编程 react是面向组件编程的一种模式,它包含两种组件类型:函数式组件及类式组件 函数式组件 注:react17开始,函数式组件成为主流 一个基本的函数组件长这个样子 …

往期回顾:# React基础入门之虚拟Dom【一】

面向组件编程

react是面向组件编程的一种模式,它包含两种组件类型:函数式组件类式组件

函数式组件

注:react17开始,函数式组件成为主流

一个基本的函数组件长这个样子

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><title>hello_react</title></head><body><!-- 准备好一个“容器” --><div id="test"></div><!-- 引入react核心库 --><script type="text/javascript" src="./js/react.development.js"></script><!-- 引入react-dom,用于支持react操作DOM --><script type="text/javascript" src="./js/react-dom.development.js"></script><!-- 引入babel,用于将jsx转为js --><script type="text/javascript" src="./js/babel.min.js"></script><script type="text/babel">// 1、创建函数式组件function Demo() {return <h1>函数式组件</h1>;}// 2、渲染组件ReactDOM.render(<Demo />, document.getElementById("test"));</script></body>
</html>

页面效果如下:

函数名的注意事项

注意,渲染组件时,函数名称需要写成html标签的形式。此外,函数名称不能使用小写的形式:

// 1、创建函数式组件
function demo() {return <h1>函数式组件</h1>;
}
// 2、渲染组件
ReactDOM.render(<demo />, document.getElementById("test"));

如上,如果写成小写的形式,控制台会报错

这和Jsx的语法规则有关

遇到 <开头的代码, 以标签的语法解析: html同名标签转换为html同名元素, 其它标签需要特别解析

函数的执行者

上述代码中,我们并没有执行Demo函数,但当我们将它作为标签使用时,react帮我们执行了这个函数。

函数内的this指向

正常情况下,一个函数内的this应该指向window,但下面的示例中,this会是undefined

<script type="text/babel">// 1、创建函数式组件function Demo() {console.log("this", this);return <h1>函数式组件</h1>;}// 2、渲染组件ReactDOM.render(<Demo />, document.getElementById("test"));
</script>

原因很简单,我们的代码是在babel环境下执行的,bable会开启严格模式,让我们this的指向不是window。

我们可以验证一下,打开bable官网,

复制上述代码进去

可以看到,我们函数式组件最终会被编译成一个普通函数(这印证了JSX是语法糖)。

类式组件

注:在最新的react18版本以后,这种写法已经不推荐了,但这是学习了解react重要的一环!

一个基本的类式组件长这个样子

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><title>hello_react</title></head><body><!-- 准备好一个“容器” --><div id="test"></div><!-- 引入react核心库 --><script type="text/javascript" src="./js/react.development.js"></script><!-- 引入react-dom,用于支持react操作DOM --><script type="text/javascript" src="./js/react-dom.development.js"></script><!-- 引入babel,用于将jsx转为js --><script type="text/javascript" src="./js/babel.min.js"></script><script type="text/babel">// 1、创建类组件class MyComponent extends React.Component {render() {return <h1>这是一个类组件</h1>;}}// 渲染组件ReactDOM.render(<MyComponent />, document.getElementById("test"));</script></body>
</html>

页面效果

类式组件的写法

类式组件必须继承React.Component这个父类,且函数内部必须调用render函数

class MyComponent extends React.Component {render() {return <h1>这是一个类组件</h1>;}
}

我们知道,类的使用必须使用new关键词,但是上述代码我们并没有使用,那么MyComponent的实例是什么时候创建的?

在渲染组件时,react帮我们执行的。

ReactDOM.render(<MyComponent />, document.getElementById("test"));

执行代码后:

  • react解析组件标签,找到了MyComponent组件
  • 发现组件是使用类定义的,随后new出类的实例,并通过实例调用原型上的render方法
  • 将render返回的虚拟Dom转换为真实Dom,随后呈现在页面中

render函数

render函数定义位置

根据类的知识,render函数是定义在MyComponent类 的原型上的,我们打开控制台验证下

render函数中的this指向

根据类的知识,我们知道render中的this应该是MyComponent的实例对象

我们打印下

// 1、创建类组件
class MyComponent extends React.Component {render() {console.log("render中的this", this);return <h1>这是一个类组件</h1>;}
}

可以看出,this确实是MyComponent的实例对象,同时也可以验证实例对象的prototype上的存在MyComponen的render方法

组件中的属性

观察打印出来的实例对象,我们可以发现实例对象上存在很多属性方法,如contextprops

这些方法我们没有在MyComponent类中定义,那它必然来源于继承的父类React.Component。这些组件上的属性方法,我们将在下一篇文章熟悉。

http://www.15wanjia.com/news/13124.html

相关文章:

  • 宜春seo网站推广公司产品推广方案
  • 网站怎么换服务器郑州竞价托管公司哪家好
  • 贵阳个人做网站福建seo优化
  • 动态网站托管口碑营销的案例
  • 做一网站要学些什么个人怎么接外贸订单
  • 自己的网站怎么做下载链接东莞seo推广机构帖子
  • 网站建设毕业答辩问题广告信息发布平台
  • 昆明建网站公司网络销售适合什么人做
  • 陕西建设注册中心网站成都排名推广
  • 哪个网站做欧洲旅游攻略好服务器ip域名解析
  • 艾科斗少儿编程加盟免费的电脑优化软件
  • 新人做网站盈利b2b免费外链发布
  • wordpress启动广告seo点击排名器
  • 物流企业网站建设自媒体135网站免费下载安装
  • 做电影网站要多少钱设计网络营销方案
  • wordpress自动 插件优化大师手机版
  • seo优化网站建设哪家好网站优化关键词排名
  • 中英文网站建设需要懂英语吗房管局备案查询网站
  • 哈尔滨站建站时间关键词分为哪三类
  • 泉州市做网站优化口碑营销的步骤
  • 内蒙古建设工程交易中心网站百度客服中心人工电话
  • 群辉nas怎么做网站seo实战论坛
  • 低价网站设计seo免费入门教程
  • 徐州网站开发服务seo在线网站推广
  • 武汉做网站的公司软文什么意思
  • 网站做跳转的要求百度网站app下载
  • 门户网站管理建设肇庆seo优化
  • 网站建设自查维护报告在线资源搜索神器
  • 网络工程公司的业务厦门最好的seo公司
  • 咸宁网站制作公司厦门百度竞价