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

设计与绘制一个网站首页北京债务优化公司

设计与绘制一个网站首页,北京债务优化公司,青岛开发区做网站,橙子官方网站文章目录 单项数据绑定通过onChange方法,实现双向数据绑定 单项数据绑定 在 Vue 中,可以通过 v-model 指令来实现双向数据绑定。但是,在 React 中并没有指令的概念,而且 React 默认不支持 双向数据绑定。 React 只支持&#xff…

文章目录

    • 单项数据绑定
    • 通过onChange方法,实现双向数据绑定

单项数据绑定

在 Vue 中,可以通过 v-model 指令来实现双向数据绑定。但是,在 React 中并没有指令的概念,而且 React 默认不支持 双向数据绑定

React 只支持,把数据从 state 上传输到 页面,但是,无法自动实现数据从 页面 传输到 state 中 进行保存。

React中,只支持单项数据绑定,不支持双向数据绑定。不信的话,我们来看下面这个例子:

import React from "react";export default class MyComponent extends React.Component {constructor(props) {super(props);this.state = {msg: "这是 MyComponent 组件 默认的msg"};}render() {return (<div><h3>呵呵哒</h3><input type="text" value={this.state.msg} /></div>);}}

上方代码中,我们尝试在 input文本框中读取 state.msg 的值,运行结果中,却弹出了警告:

20190213_2000.png

Warning: Failed prop type: You provided a `value` prop to a form field without an `onChange` handler. This will render a read-only field. If the field should be mutable use `defaultValue`. Otherwise, set either `onChange` or `readOnly`.

通过onChange方法,实现双向数据绑定

如果针对 表单元素做 value 属性绑定,那么,必须同时为 表单元素 绑定 readOnly, 或者提供 onChange 事件:

  • 如果是绑定readOnly,表示这个元素只读,不能被修改。此时,控制台就不会弹出警告了。

  • 如果是绑定onChange,表示这个元素的值可以被修改,但是,要自己定义修改的逻辑。

绑定readOnly的举例如下:(表示value中的数据是只读的)

	<input type="text" value={this.state.msg} readOnly />

绑定 onChange 的举例如下:(通过onChange方法,实现双向数据绑定)

(1)index.html:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title>
</head><body><!-- 容器,通过 React 渲染得到的 虚拟DOM,会呈现到这个位置 --><div id="app"></div>
</body></html>

(2)main.js:

// JS打包入口文件
// 1. 导入包
import React from "react";
import ReactDOM from "react-dom";// 导入组件
import MyComponent from "./components/MyComponent.jsx";// 使用 render 函数渲染 虚拟DOM
ReactDOM.render(<div><MyComponent></MyComponent></div>,document.getElementById("app")
);

(3)components/MyComponent.jsx

import React from "react";export default class MyComponent extends React.Component {constructor(props) {super(props);this.state = {msg: "这是组件 默认的msg"};}render() {return (<div><h1>呵呵哒</h1><inputtype="text" value={this.state.msg} onChange={this.txtChanged} ref="txt" /><h3>{"实时显示msg中的内容:" + this.state.msg}</h3></div>);}// 为 文本框 绑定 txtChanged 事件txtChanged = (e) => {// 获取 <input> 文本框中 文本的3种方式://  方式一:使用 document.getElementById//  方式二:使用 ref// console.log(this.refs.txt.value);//  方式三:使用 事件对象的 参数 e 来拿// 此时,e.target 就表示触发 这个事件的 事件源对象,得到的是一个原生的JS DOM 对象。在这个案例里,e.target就是指文本框// console.log(e.target.value);this.setState({msg: e.target.value});};
}

工程文件:ReactDemo.zip

http://www.dtcms.com/wzjs/397672.html

相关文章:

  • 网站制作教学关键词密度查询站长工具
  • 电子商务网站域名注册方法国内搜索引擎优化的公司
  • 佛山网站建设公司电话推广软文发稿
  • 建网站跟建网店的区别今日头条新闻最新
  • 昭通市公安局网站是谁做的百度扫一扫识别图片
  • 桂林旅游网站制作搜索引擎关键词广告
  • 网站建设规划书的目的重庆seo服务
  • 企业网站备案需要什么资料seo推广公司有哪些
  • 企业管理培训课程定制北京seo人员
  • react做的电商网站能上线吗搜索引擎营销经典案例
  • 百度云注册域名可以做网站明码windows优化软件
  • 微网站 布局北京官方seo搜索引擎优化推荐
  • 网站运营面试问题百度端口开户推广
  • 德州网站设计2345网址大全
  • 在网站上有中英切换怎么做北京网络推广公司排行
  • 珲春网站建设国家税务总局网
  • 网站开发中所需要的绘图工具免费浏览外国网站的软件
  • 360上做网站网络广告创意
  • 用安卓做网站凤凰网台湾资讯
  • 资阳的网站建设营销软文代写
  • 怎么做网站推广线下找培训机构的网站
  • 做网站页面代码怎么在百度上面打广告
  • 河池市城乡住房建设厅网站百度推广关键词质量度
  • 福州网站制作哪里有网站推广优化
  • 崆峒区建设局网站媒体代发网站
  • wordpress 导出 主题西安市seo排名按天优化
  • 做网站找谷谷网络比较好网上推广产品怎么做
  • 临沂网站seo软文广告文案案例
  • 北京网站排名seo百度高级搜索入口
  • 家庭做网站店铺推广软文范例