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

武汉网站建设招聘百度seo公司哪家强一点

武汉网站建设招聘,百度seo公司哪家强一点,开发html网页的软件,网站开发bs模式和cs模式state 和 props 主要的区别在于 props 是不可变的,而 state 可以根据与用户交互来改变。 所以,有些容器组件需要定义 state 来更新和修改数据。 而子组件只能通过 props 来传递数据。 props 使用 Demo.js : import React from reactfunct…

stateprops 主要的区别在于 props 是不可变的,而 state 可以根据与用户交互来改变。

所以,有些容器组件需要定义 state 来更新和修改数据。 而子组件只能通过 props 来传递数据。

props 使用

Demo.js

import React from 'react'function Demo (props) {return (<div><h1>name: {props.name}</h1><h1>message: {props.message}</h1><h1>phone: {props.phone}</h1></div>)
}export default Demo

App.js 中引入组件:

import './assets/css/App.css';
import Demo from './components/Demo'function App () {return (<div className="App"><Demo name='index' message='哈哈哈' phone="12312" /></div>);
}export default App;

页面效果:
在这里插入图片描述

默认 Props

可以通过组件类的 defaultProps 属性为 props 设置默认值:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<title>React demo</title>
<script src="https://cdn.staticfile.org/react/16.4.0/umd/react.development.js"></script>
<script src="https://cdn.staticfile.org/react-dom/16.4.0/umd/react-dom.development.js"></script>
<script src="https://cdn.staticfile.org/babel-standalone/6.26.0/babel.min.js"></script>
</head>
<body><div id="example"></div>
<script type="text/babel">
class HelloMessage extends React.Component {render() {return (<div><h1>name: {this.props.name}</h1><h1>phone: {this.props.phone}</h1><h1>message: {this.props.message}</h1></div>);}
}HelloMessage.defaultProps = {message: '我是props.message的默认值!'
};const element = <HelloMessage name='index' phone='12312'/>;ReactDOM.render(element,document.getElementById('example')
);
</script></body>
</html>

页面效果:
在这里插入图片描述

组合使用 State 和 Props

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<title>React Demo</title>
<script src="https://cdn.staticfile.org/react/16.4.0/umd/react.development.js"></script>
<script src="https://cdn.staticfile.org/react-dom/16.4.0/umd/react-dom.development.js"></script>
<script src="https://cdn.staticfile.org/babel-standalone/6.26.0/babel.min.js"></script>
</head>
<body><div id="example"></div>
<script type="text/babel">class Demo extends React.Component {constructor() {super();this.state = {name: "xiaoming",msg: "https://www.baidu.com"}}render() {return (<div><Name name={this.state.name} /><Link site={this.state.msg} /></div>);}
}class Name extends React.Component {render() {return (<h1>{this.props.name}</h1>);}
}class Link extends React.Component {render() {return (<a href={this.props.site}>{this.props.site}</a>);}
}ReactDOM.render(<Demo />,document.getElementById('example')
);
</script></body>
</html>

页面效果:
在这里插入图片描述
上面实例,在父组件中设置 state, 并通过在子组件上使用 props 将其传递到子组件上。在 render 函数中, 设置 namesite 来获取父组件传递过来的数据。

Props 验证

Props 验证使用 propTypes,可以保证应用组件被正确使用,React.PropTypes 提供很多验证器 (validator) 来验证传入数据是否有效。当向 props 传入无效数据时,JavaScript 控制台会抛出警告。

类型验证

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<title>React demo</title>
<script src="https://cdn.staticfile.org/react/16.4.0/umd/react.development.js"></script>
<script src="https://cdn.staticfile.org/react-dom/16.4.0/umd/react-dom.development.js"></script>
<script src="https://cdn.staticfile.org/prop-types/15.6.1/prop-types.js"></script>
<script src="https://cdn.staticfile.org/babel-standalone/6.26.0/babel.min.js"></script>
</head>
<body><div id="example"></div>
<script type="text/babel">
var title = "this is a title";
class Demo extends React.Component {render() {return (<h1>Hello, {this.props.title}</h1>);}
}Demo.propTypes = {title: PropTypes.string
};
ReactDOM.render(<Demo title={title} />,document.getElementById('example')
);
</script></body>
</html>

以上实例创建一个 Demo 组件,属性 title 是必须的且是字符串,非字符串类型会自动转换为字符串。

页面效果:
在这里插入图片描述

当修改 title 的值为其他类型时,如下:

var title = true

运行代码会抛出错误:
在这里插入图片描述

是否为空验证

任意类型加上 isRequired 来使 prop 不可空。

<Demo title={title} /> 修改为 <Demo />

然后,修改校验 Demo.propTypes = { title: PropTypes.string } 为如下:

Demo.propTypes = {title: PropTypes.string.isRequired
};

运行代码会抛出错误:
在这里插入图片描述

http://www.hengruixuexiao.com/news/49396.html

相关文章:

  • 在线flash相册网站源码浙江网站建设制作
  • 郑州七彩网站建设公司 概况网络营销的目的和意义
  • 深圳石岩建网站营销型网站建设托管
  • 做网站要买服务器吗专业拓客公司联系方式
  • 商业类网站的设计与制作国内看不到的中文新闻网站
  • 报名网站辽宁省建设银行企业推广宣传方案
  • 多个网站给一个网站推广百度精准搜索
  • 要怎么推广网站买号链接
  • 网站成功秘诀郑州高端网站建设
  • 外国ps修图网站短链接在线生成官网
  • 做二手网站赚钱不免费发软文的网站
  • 阜沙网站建设事件营销成功案例
  • wordpress 标题字数企业seo关键词优化
  • 做笔记网站临安网站seo
  • 广州站是广州火车站吗关键词林俊杰在线听免费
  • 建设银行的网站为什么这么卡互联网营销师有什么用
  • 北京到广州快递要几天湖南seo服务电话
  • 滑县住房和城乡建设局网站个人如何做网络推广
  • wordpress所有外链本地化济南seo小黑seo
  • 岳阳建设商城网站公司微信营销方案
  • 做网投网站好软文营销是什么
  • 装潢设计师要学什么公众号排名优化软件
  • .net wap网站模板谁有推荐的网址
  • 做网站和做系统有什么区别上海全国关键词排名优化
  • 十佳深圳网站设计站长查询
  • 网站背投广告代码网盘app下载
  • 河南新闻头条最新事件福州seo网站推广优化
  • 宁波建设网证书查询平台官网深圳网站快速排名优化
  • 工作了应该浏览器哪些网站佛山市人民政府门户网站
  • 网站后台栏目根据什么做的网站建设图片