Table des matières
1.JSX使得在模板插入js变量
Hellow, Pan
I like React very much!
2.ReactDomTest
Hello, world!
3.使用JSX支持JS与HTML混用
4.创建组件
Hello, {this.props.name}
5.使用属性 props
6.PropsType
{this.props.title}
7.使用默认属性 GetDefaultProps
8.获取真实dom
9.通过State改变状态
10.使用表单监听,更好的用户交互
11.使用JSBIn 直接在浏览器运行,调试JSX 很方便
Maison interface Web tutoriel HTML ReactJs基础_html/css_WEB-ITnose

ReactJs基础_html/css_WEB-ITnose

Jun 21, 2016 am 08:58 AM

  • 因项目某些页面需要重构, 使用了ReactJs, 所以做了一些小demo

  • 源码地址,含有wiki

1.JSX使得在模板插入js变量

<!DOCTYPE html><html>    <head>        <script src="../build/react.js"></script>        <script src="../build/react-dom.js"></script>        <script src="../build/browser.min.js"></script>    </head>    <body>        <div id="example"></div>        <script type="text/babel">            //JSX 允许直接在模板插入 JavaScript 变量。如果这个变量是一个数组,则会展开这个数组的所有成员            var arr = [                 <h1 id="Hellow-Pan"> Hellow, Pan </h1>,                <h2 id="I-like-React-very-much"> I like React very much! </h2>,            ];            ReactDOM.render(                <div>{arr}</div>,                document.getElementById('example')            );        </script>    </body></html>
Copier après la connexion

2.ReactDomTest

<!DOCTYPE html><html>    <head>        <script src="../build/react.js"></script>        <script src="../build/react-dom.js"></script>        <script src="../build/browser.min.js"></script>    </head>    <body>        <div id="example"></div>        <script type="text/babel">            ReactDOM.render(                <h1 id="Hello-world">Hello, world!</h1>,                document.getElementById('example')                );        </script>    </body></html>
Copier après la connexion

3.使用JSX支持JS与HTML混用

<!DOCTYPE html><html>    <head>        <script src="../build/react.js"></script>        <script src="../build/react-dom.js"></script>        <script src="../build/browser.min.js"></script>    </head>    <body>        <div id="example"></div>        <script type="text/babel">            var names = ['Shine', 'Pans', 'Panshang'];            //jsx可以让html和js混用, <>是html, {}是js            ReactDOM.render(                <div>                {                    names.map(function (name){                        return <div> Hello, {name}!</div>                    })                }                </div>,                document.getElementById('example')            );        </script>    </body></html>
Copier après la connexion

4.创建组件

<!DOCTYPE html><html>    <head>        <script src="../build/react.js"></script>        <script src="../build/react-dom.js"></script>        <script src="../build/browser.min.js"></script>    </head>    <body>        <div id="example"></div>        <script type="text/babel">        //HelloMessage 是一个组件类。模板插入 <HelloMessage /> 时,会自动生成 HelloMessage 的一个实例            var HelloMessage = React.createClass({                render: function(){                    return <h1 id="Hello-this-props-name">Hello, {this.props.name}</h1>;                }            });            ReactDOM.render(                <HelloMessage name = "Pan" />,                document.getElementById('example')            );        </script>    </body></html>
Copier après la connexion

5.使用属性 props

<!DOCTYPE html><html>    <head>        <script src="../build/react.js"></script>        <script src="../build/react-dom.js"></script>        <script src="../build/browser.min.js"></script>    </head>    <body>        <div id="example"></div>        <script type="text/babel">        //NoteList 组件有两个 span 子节点,它们都可以通过 this.props.children 读取            var NotesList = React.createClass({              render: function() {                return (                  <ol>                  {                    React.Children.map(this.props.children, function (child) {                      return <li>{child}</li>;                    })                  }                  </ol>                );              }            });            ReactDOM.render(              <NotesList>                <span>hello</span>                <span>Pan! </span>              </NotesList>,              document.body            );        </script>    </body></html>
Copier après la connexion

6.PropsType

<!DOCTYPE html><html>    <head>        <script src="../build/react.js"></script>        <script src="../build/react-dom.js"></script>        <script src="../build/browser.min.js"></script>    </head>    <body>        <div id="example"></div>        <script type="text/babel">            var MyTitle = React.createClass({                //要求title的属性的data类型是string,只能是string                propTypes: {                    title: React.PropTypes.string.isRequired,                },                render: function() {                    return <h1 id="this-props-title"> {this.props.title} </h1>;                }            });            //测试部分, 将title属性设置成 int类型, 然后会报错            //将123用引号包起来标示为字符串类型将不在报错            var data = 123;            ReactDOM.render(                <MyTitle title = {data} />,                document.body                );        </script>    </body></html>
Copier après la connexion

7.使用默认属性 GetDefaultProps

<!DOCTYPE html><html>    <head>        <script src="../build/react.js"></script>        <script src="../build/react-dom.js"></script>        <script src="../build/browser.min.js"></script>    </head>    <body>        <div id="example"></div>        <script type="text/babel">        //获取默认的属性        //获取的是title的值            var MyTitle = React.createClass({              getDefaultProps : function () {                return {                  title : 'shinepans'                };              },              render: function() {                 return <h1 id="this-props-title"> {this.props.title} </h1>;               }            });            ReactDOM.render(              <MyTitle />,              document.body            );        </script>    </body></html>
Copier après la connexion

8.获取真实dom

<!DOCTYPE html><html>    <head>        <script src="../build/react.js"></script>        <script src="../build/react-dom.js"></script>        <script src="../build/browser.min.js"></script>    </head>    <body>        <div id="example"></div>        <script type="text/babel">            var MyComponent = React.createClass({                handleClick: function() {                //监听点击事件, 聚焦输入框                this.refs.myTextInput.focus();                },                render: function() {                    return (                    <div>                        <input type="text" ref="myTextInput" />                        <input type="button" value="Focus the text input" onClick={this.handleClick} />                    </div>                        );                    }                });            ReactDOM.render(                <MyComponent />,                document.getElementById('example')            );        </script>    </body></html>
Copier après la connexion

9.通过State改变状态

<!DOCTYPE html><html>    <head>        <meta charset="utf-8")> </meta>        <script src="../build/react.js"></script>        <script src="../build/react-dom.js"></script>        <script src="../build/browser.min.js"></script>    </head>    <body>        <div id="example"></div>        <script type="text/babel">            var LikeButton = React.createClass({              getInitialState: function() {                return {liked: false};              },              handleClick: function(event) {                this.setState({liked: !this.state.liked});              },              //转换状态, 喜欢或不喜欢              render: function() {                var text = this.state.liked ? '喜欢了' : '还没喜欢';                return (                  <p onClick={this.handleClick}>                    你{text}这个.点击文本改变你的状态.                  </p>                );              }            });            ReactDOM.render(              <LikeButton />,              document.getElementById('example')            );        </script>    </body></html>
Copier après la connexion

10.使用表单监听,更好的用户交互

<!DOCTYPE html><html>    <head>        <meta charset="utf-8")> </meta>        <script src="../build/react.js"></script>        <script src="../build/react-dom.js"></script>        <script src="../build/browser.min.js"></script>    </head>    <body>        <div id="example"></div>        <script type="text/babel">        //监听textarea的变化, 变化了就更新p标签里的内容        //下面初始化了 输入框和p的初始值            var Input = React.createClass({              getInitialState: function() {                return {value: '请在文本框输入文本'};              },              handleChange: function(event) {                this.setState({value: event.target.value});              },              render: function () {                var value = this.state.value;                return (                  <div>                    <textarea rows="10" cols="30" value={value} onChange={this.handleChange} />                    <p>{value}</p>                  </div>                );              }            });            ReactDOM.render(<Input/>, document.body);        </script>    </body></html>
Copier après la connexion

11.使用JSBIn 直接在浏览器运行,调试JSX 很方便

  • JSBib网址

令文字渐变效果, 使用了props, 计时器等, 源码参考开始时给出的源代码地址

by: 潘尚

time: 2016.1.30

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Difficulté à mettre à jour la mise en cache des pages Web officielles du compte: comment éviter l'ancien cache affectant l'expérience utilisateur après la mise à jour de la version? Difficulté à mettre à jour la mise en cache des pages Web officielles du compte: comment éviter l'ancien cache affectant l'expérience utilisateur après la mise à jour de la version? Mar 04, 2025 pm 12:32 PM

Le cache de mise à jour de la page Web du compte officiel, cette chose est simple et simple, et elle est suffisamment compliquée pour en boire un pot. Vous avez travaillé dur pour mettre à jour l'article officiel du compte, mais l'utilisateur a toujours ouvert l'ancienne version. Dans cet article, jetons un coup d'œil aux rebondissements derrière cela et comment résoudre ce problème gracieusement. Après l'avoir lu, vous pouvez facilement faire face à divers problèmes de mise en cache, permettant à vos utilisateurs de toujours ressentir le contenu le plus frais. Parlons d'abord des bases. Pour le dire franchement, afin d'améliorer la vitesse d'accès, le navigateur ou le serveur stocke des ressources statiques (telles que des images, CSS, JS) ou du contenu de la page. La prochaine fois que vous y accédez, vous pouvez le récupérer directement à partir du cache sans avoir à le télécharger à nouveau, et il est naturellement rapide. Mais cette chose est aussi une épée à double tranchant. La nouvelle version est en ligne,

Comment utiliser les attributs de validation du formulaire HTML5 pour valider l'entrée utilisateur? Comment utiliser les attributs de validation du formulaire HTML5 pour valider l'entrée utilisateur? Mar 17, 2025 pm 12:27 PM

L'article discute de l'utilisation des attributs de validation de formulaire HTML5 comme les limites requises, motifs, min, max et longueurs pour valider la saisie de l'utilisateur directement dans le navigateur.

Quelles sont les meilleures pratiques pour la compatibilité entre les navigateurs dans HTML5? Quelles sont les meilleures pratiques pour la compatibilité entre les navigateurs dans HTML5? Mar 17, 2025 pm 12:20 PM

L'article examine les meilleures pratiques pour assurer la compatibilité des navigateurs de HTML5, en se concentrant sur la détection des fonctionnalités, l'amélioration progressive et les méthodes de test.

Comment ajouter efficacement les effets de course aux images PNG sur les pages Web? Comment ajouter efficacement les effets de course aux images PNG sur les pages Web? Mar 04, 2025 pm 02:39 PM

Cet article démontre un ajout de bordure PNG efficace aux pages Web à l'aide de CSS. Il soutient que CSS offre des performances supérieures par rapport à JavaScript ou à des bibliothèques, détaillant comment ajuster la largeur, le style et la couleur des bordures pour un effet subtil ou proéminent

Quel est le but du & lt; datalist & gt; élément? Quel est le but du & lt; datalist & gt; élément? Mar 21, 2025 pm 12:33 PM

L'article traite du HTML & lt; Datalist & GT; élément, qui améliore les formulaires en fournissant des suggestions de saisie semi-automatique, en améliorant l'expérience utilisateur et en réduisant les erreurs. COMMANDE COMPRES: 159

Quel est le but du & lt; Progress & gt; élément? Quel est le but du & lt; Progress & gt; élément? Mar 21, 2025 pm 12:34 PM

L'article traite du HTML & lt; Progress & GT; élément, son but, son style et ses différences par rapport au & lt; mètre & gt; élément. L'objectif principal est de l'utiliser & lt; Progress & gt; pour l'achèvement des tâches et & lt; mètre & gt; pour stati

Comment utiliser le html5 & lt; time & gt; élément pour représenter les dates et les temps sémantiquement? Comment utiliser le html5 & lt; time & gt; élément pour représenter les dates et les temps sémantiquement? Mar 12, 2025 pm 04:05 PM

Cet article explique le html5 & lt; time & gt; élément de représentation sémantique de date / heure. Il souligne l'importance de l'attribut DateTime pour la lisibilité à la machine (format ISO 8601) à côté du texte lisible par l'homme, stimulant AccessIbilit

Quel est le but du & lt; mètre & gt; élément? Quel est le but du & lt; mètre & gt; élément? Mar 21, 2025 pm 12:35 PM

L'article traite du HTML & lt; mètre & gt; élément, utilisé pour afficher des valeurs scalaires ou fractionnaires dans une plage, et ses applications courantes dans le développement Web. Il différencie & lt; mètre & gt; De & lt; Progress & gt; et ex

See all articles