react初识

如下是在研究中记录的笔记:

1,作用:局部的更新dom结构;虚拟dom保证性能
2,和mvc不同,mvc是对于技术上的分离(分类),而react是组件上的分离,每个视图模块分离,复用,以视图模块为单位
3,2的说法确实有所体现,而且,我感觉好像模板引擎啊,难道是我幼稚?
4,浅析语法:
html : <div id=‘box‘></div>
jsx
<script type=‘text/babel‘>
js code...
ReactDOM.render(html_jsx_deal,document.getElementById(‘box‘));
</script>
5,还可以将jsx代码放在js文件中,然后引入,<script type=‘text/babel‘ src=‘..‘></script>,这样引入,后面的引入的模块错了,
运行也不会受到影响的
6.自设定的属性要加data-mine在标签中
7.没有if else ,用三目运算符
8,js表达式写在{}中,注释也写在花括号中
9,var show = {
fontSize:30,
color:‘red‘,
background:‘black‘
}
ReactDOM.render(
//html标签后面是逗号
<h2 style={show}>hello world this is my first react js</h2>,
document.getElementById(‘show‘)
)
内联样式的写法,而且是推荐内联样式的
10,感觉jsx不可以遍历对象我日诸如for()方法都不可用
11,browser.js上线后,要放到服务器完成,否则很耗时间?????????????????有转码工具进行转码

12****important
遍历的表达式外层要有父标签的包裹,否则会报错,如:而且还证明了对象是可以处理的
var you = [{name:‘me‘},{name:‘zhongyaji‘}];
ReactDOM.render(
<h3></h3>
//如这种回报错
//{
// you.map(function(e){
// return <h2>{e.name}</h2>
// })
//}

//这种就ok,循环loop处有h2的包裹
<h2>
{
you.map(function(e){
return <h2>{e.name}</h2>
})
}
</h2>

,
document.getElementById(‘one‘)
)
13,这里研究是否可以用for和单纯的对象:
这里是不能够这么写的:
var lover= {name:‘zhongyaji‘,age:‘21‘,position:‘princess‘,emotion:‘deep and would not give up‘};
ReactDOM.render(
<h1><strong>Introduce my wife</strong></h1>
<ul>
{
for(var i in lover){
<h3>{i}:{lover[i]}</h3>
}
}
</ul>,
document.getElementById(‘two‘)
)
14,关于组件有如下亲笔栗子:---important组件开头名必须
组件调用了不能在有其他代码了,
而且,要拼接组件,只能在调用之前拼接好(符合组件:如下)
<!--组件化-->
<div id="two"></div>
<script type="text/babel">
var ModleChase = React.createClass({
render:function(){
return <h2>我的爱人组件:{this.props.lover}<h4>只能有一个顶级的元素,这个费顶级,就是只有一个父亲h2</h4></h2>
}
});
ReactDOM.render(
//果然只能有一个父元素,一女不容2男
// <h1>我的爱人是</h1>
<ModleChase lover=‘zhongyaji‘/>,
document.getElementById(‘two‘)
)
</script>
15,组件的拼接:符合组件

<!--符合组件-->
<div id="three"></div>
<script type="text/babel">
var Wuruijie = React.createClass({
render:function(){
return (<strong>emotion to zhongyaji:{this.props.say}</strong>)
}
})
var Zhongyaji = React.createClass({
render:function(){
//return后面要加小括号 坑爹啊
return (<strong>emotion to wuruijie :{this.props.say}</strong>)
}
})
var Makelove = React.createClass({
render:function(){
//这个return 有无括号无所谓
return (
<div>
{this.props.love}
<Wuruijie say=‘我爱仙女‘/>
<Zhongyaji say=‘我爱吴师傅‘/>
</div>)
}
})
ReactDOM.render(
//这个斜线必须加
<Makelove love=‘爱的构造‘/>,
document.getElementById(‘three‘)
)
</script>
注.this.props.children是它的不可自定义
16,状态的改变
寄托于组件
var ChangeState = function(){
getInitialState:function(){
return {flag:true}
},
changeHandle:function(event){
//event事件对象
//设置为相反的状态,然判断这个来給dom
this.setState:({flag:!this.state.flag});
},

render:function(){
var text = this.state.flag?‘true‘:‘false‘;
return (
<p onClick={this.changeHandle}>{text}{this.props.jj}</p>
);
}
}
17,在react中的交互靠的就是状态,对的,所以state很重要,,而且,this.state...可以得到状态,要改变,需要this.setState,只要状态改变了,
自动调用this.render来渲染
18,渐渐体会到了react的精髓,暴露的仅仅是有着不同属性的html自定义标签,然后,属性和动态的,都由React.createClass({中的方法})
来进行控制,变化,主要靠state,对于一个组件是全局的,还有props,对于一个组件的属性也是全局的
19,react在state改变之后,自动调用render来进行渲染,关于如何渲染?触发改变?规定方法,时间触发了就改变.移除更新也是
20,style的写法应该是 <div style={{color:red;background:blue}}></div>
21,不应将转化放在客户端靠browser.js,很慢,而应当在服务端时候,用工具,就转化编译好,npm install -g react-tools
然后,jsx --watch origin/ use/来监听和转化!

如下时候亲手亲测代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>react</title>
    <script type="text/javascript" src=‘../lazyload/jquery-2.1.4.min.js‘></script>
    <script type="text/javascript" src=‘react.min.js‘></script><!--核心库-->
    <script type="text/javascript" src=‘react-dom.min.js‘></script><!--dom操作-->
    <script type="text/javascript" src=‘browser.js‘></script><!--jsx转化为js-->
</head>
<body>
    <div id="show"></div>
    <div id="list"></div>
    <div id=‘love‘></div>
    <div id=‘hate‘></div>
    <div id=‘hated‘></div>
    <!--这里是jsx-->
    <script type="text/babel" src=‘react_out.js‘></script>
    <script type="text/babel">

        //是小括号
        //ReactDOM外部写js,内部写ReactDOM.render();
        var name = [‘wuruijie‘,‘zhongyaji‘];
        console.log(name);
        //遍历数组的
        ReactDOM.render(
            <ul>
            {
                name.map(function(each){
                    return <li>lovers:{each}</li>
                })
            }
            </ul>,
            document.getElementById(‘list‘)
        );
        //数组的
        var arr = [<h1>我要加油为了钟亚姬</h1>,<h2>一定要等我</h2>];
        ReactDOM.render(
            <div>我的感觉{arr}我的感觉</div>,
            document.getElementById(‘love‘)
            )
    </script>
    <!--对象的测试-->
    <div id="one"></div>
    <script type="text/babel">
        var you = [{name:‘me‘},{name:‘zhongyaji‘}];
        ReactDOM.render(
            <h3>
            {
                you.map(function(e){
                    return <h2>{e.name}</h2>
                })
            }
            </h3>
            ,
            document.getElementById(‘one‘)
        )
    </script>

    <!--组件化-->
    <div id="two"></div>
    <script type="text/babel">
        var ModleChase = React.createClass({
            render:function(){
                return (<h2>我的爱人组件:{this.props.lover}<h4>只能有一个顶级的元素,这个费顶级,就是只有一个父亲h2</h4></h2>)
            }
        });
        var Angle = React.createClass({
            render:function(){
                return (<h3>hahahahhahahhah{this.props.say}</h3>)

            }
        })
        ReactDOM.render(
            // <h1>我的爱人是</h1>s
            // <Angle say=‘i love you zhongyaji‘/>
            <ModleChase lover=‘zhongyaji‘/>,
            document.getElementById(‘two‘)
            )
    </script>
    <!--符合组件-->
    <div id="three"></div>
    <script type="text/babel">
        var Wuruijie = React.createClass({
            render:function(){
                return (<strong>emotion to zhongyaji:{this.props.say}</strong>)
            }
        })
        var Zhongyaji = React.createClass({
            render:function(){
                //return后面要加小括号  坑爹啊
                return (<strong>emotion to wuruijie :{this.props.say}</strong>)
            }
        })
        var Makelove = React.createClass({
            render:function(){
                return (
                    <div>
                        {this.props.love}
                        <Wuruijie say=‘我爱仙女‘/>
                        <Zhongyaji say=‘我爱吴师傅‘/>
                    </div>)
            }
        })
        ReactDOM.render(
            <Makelove love=‘爱的构造‘/>,
            document.getElementById(‘three‘)
            )
    </script>

    <!--状态,的改变-->
    <div id="fairy"></div>
    <script type="text/babel">
        var Changeemotion = React.createClass({
            //初始化状态,用true和false来赋值,普遍的,这个函数固定的-亲测如此
            getInitialState:function(){
                //这个函数一般都是返回一个初始状态
                return {emotion:true};
            },
            //这个函数是自定义的
            changHandler:function(event){
                //event是事件对象,固定的setState
                // this.setState({emotion:!this.state.emotion});
                //两个一样和上面的写法
                this.setState(function(state){
                    return {emotion:!state.emotion}
                })
            },
            //设定默认的props,不指定时候默认  getDefaultProps
            getDefaultProps:function(){
                return {
                    other:‘<em>hahah</em>‘
                };
            },
            //拼接
            render:function(){
                var text = this.state.emotion?‘我真的爱你‘:‘我有苦衷,但是还是爱你‘;
                return (
                    <strong data-hello=‘you‘ onClick={this.changHandler}>这个情感是:{this.props.other}{text}</strong>
                    )
            }
        })

        ReactDOM.render(
            //此处就算不写other,也有默认的
                <Changeemotion />,
                document.getElementById(‘fairy‘)
            )
    </script>

    <!--联动狂-->
    <div id="all_move"></div>
    <script type="text/babel">
        var Content = React.createClass({

            render:function(){
                return (
                    <div>
                        <input value={this.props.emotion} type=‘text‘ onChange={this.props.deal_fun}/>
                        <h1 >{this.props.emotion}</h1>
                    </div>
                    )
            }
        })
        var Show = React.createClass({
            getInitialState:function(){
                return {emotion:‘We love toghether!‘};
            },
            inputHandler:function(event){
                this.setState({emotion:event.target.value});
            },
            render:function(){
                return (
                    <div>
                        <Content emotion={this.state.emotion} deal_fun={this.inputHandler}></Content>
                    </div>
                    )
            }
        });
        ReactDOM.render(
            <Show></Show>,
            document.getElementById(‘all_move‘)
            )
    </script>
    <!--ajax实现-->
    <div id="ajax"></div>
    <script type="text/babel">
    //建立一个ajax功能的标签
        var Ajax_label = React.createClass({
            //一般都由的初始化state,贯穿一条线
            getInitialState:function(){
                return {
                    modle:{
                        name:‘modle‘,
                        express:‘the protector of princess‘
                    },
                    lover:{
                        name:‘she‘,
                        age:‘16‘,
                        emotion:‘deep and deep‘
                    }
                }
            },
            //这里的bind是为了保证this的指向始终指向实体元素(我们所构造的)
            componentDidMount:function(){
                this.serverRequest = $.get(this.props.path,function(data){
                    console.log(data);
                    this.setState({
                        lover:data
                    })
                }.bind(this),‘json‘);
            },
            //当组件移除时候,应当销毁的操作
            componentWillUnmount:function(){
                this.serverRequest.abort();
            },
            render:function(){
                return (
                    <div>
                        <h2>modle_msg:{this.state.modle.name} and duty on {this.state.modle.express}</h2>
                        <h1>fairy_msg:{this.state.lover.name} and age is {this.state.lover.age} and {this.state.lover.emotion}</h1>
                    </div>
                )
            }
        })

        setTimeout(function(){
            ReactDOM.render(
                <Ajax_label path=‘lover.json‘/>,
                document.getElementById(‘ajax‘)
                )
        },10000)
    </script>

</body>
</html>
时间: 2024-10-24 20:39:43

react初识的相关文章

前端-【学习心得】-react初识

刚写好的文章一不小心点错界面被覆盖掉,那种心情真tm酸爽,好了都怪自己不小心. 发完牢骚还是要继续重来. 在介绍react之前首先要说说为什么用它. 我最初发现他时在material ui这个前端实现框架里面.这个框架的实现使用的正式react, react是由facebook 工程师提出来的前端组件化思想的实现. 前端组件化的思想出现是因为大型项目需求的刺激.为了优雅的实现大型项目,我们必须把它一块一块的分离出来再去实现. 这里给大家一篇关于探讨界面组件化的文章: http://bradfro

React 初识

mark 参考: React 官网 - Eng:React 中文文档: React 入门实例教程 -阮一峰: 原文地址:https://www.cnblogs.com/wjcx-sqh/p/9195851.html

React初识整理(一)

一.React的特点 1.自动化的UI状态管理:自动完成数据变化与界面效果的更新. 2.虚拟DOM:创建1个虚拟的dom节点树,放在内存里(内存修改数据效率高),数据变化时先修改内存里的虚拟DOM,然后与页面的DOM进行对比,React可以做优化,优化后可只修改变化的部分,缩小节点更改的范围,从而提高效率.(正常情况下改变节点后要重新渲染页面,效率慢). 3.组件化开发:管理页面的各功能,将1个功能视为1个组件.每个组件都可以有各自的结构.样式.行为,然后把所有的组件拼合起来的开发方式.单页应用

初识React

原文地址:北云软件-初识React 专注于UI 在MVC分层设计模式中,react常被拿来实现视图层(V).React不依赖于技术栈的其他部分,因此可以方便的在现有项目中尝试用它来实现一个小特性. 虚拟DOM React从DOM中抽象出来,给出一种更简洁的编程模型,且性能表现更好.能够通过NodeJS实现服务端渲染,通过React Native开发原生app. 数据流React实现单向.响应式数据流,减少boilerplate且比传统数据绑定更容易理解. 简洁的组件React的组件都实现了一个r

初识react native遇到的问题

Andriod 使用react native时遇到的问题     打开现有项目报错: 从第一行Error可以知道是一个zip的压缩文件打不开,往下看应该是下载的Gradle文件有问题,提示也是让从新下载. 打开gradle-wrapper.properties文件看到是gradle-2.14.1-all.zip 使用的这个版本. 在安装目录下看看这个文件是否有问题. 默认安装模式是C:\Users\xiaxf\.gradle.也可以通过Android studio找到安装目录 File-sett

React Native 初识

Facebook 在 React.js Conf 2015 大会上推出了基于 JavaScript 的开源框架 React Native,本中文教程翻译自 React Native 官方文档. React Native 结合了 Web 应用和 Native 应用的优势,可以使用 JavaScript 来开发 iOS 和 Android 原生应用.在 JavaScript 中用 React 抽象操作系统原生的 UI 组件,代替 DOM 元素来渲染等. React Native 使你能够使用基于 J

React Native基础与入门(二)--初识React Native

React Native组件 React Native是用React Native框架来组建Android和IOS App的技术,那么React Native组件就是React组件.React组件让你将UI分割成独立的.可重用的一些碎片或部分,这些部分都是相互独立的. 创建组件的三种方式 1.ES6创建组件的方式 export default class HelloComponent extends Component { render() { return <Text style={{font

react native 初识react native

最近找工作,总是被问道,知不知道react Native,我直接回答,没有:这就是动力了 首先是windows下的环境搭建 参考博客: 史上最详细windows版本搭建安装react-native环境配置/ http://www.lcode.org/%E5%8F%B2%E4%B8%8A%E6%9C%80%E8%AF%A6%E7%BB%86windows%E7%89%88%E6%9C%AC%E6%90%AD%E5%BB%BA%E5%AE%89%E8%A3%85react-native%E7%8E%

初识React.js

React并不是一个框架,React提供了一些新颖的概念.库 和编程原则让你能够同时在服务端和客户端编写快速.紧凑.漂亮的代码来构建 你的web应用. React里常用的概念或技术: ES6 React 虚拟DOM(virtual DOM) 组件驱动开发(component-driven development) 不变性(immutability) 自上而下的渲染(top-down rendering) 渲染路径和优化 打包工具, ES6, 构建请求, debugging, 路由等 同构Reac