您当前的位置:首页 > 网站建设 > React
| php | asp | css | H5 | javascript | Mysql | Dreamweaver | Delphi | 网站维护 | 帝国cms | React | 考试系统 | ajax | jQuery | 小程序 |

React框架入门学习(三)使用router完成网页跳转

51自学网 2020-03-11 09:31:09
  React
React框架入门学习(三)使用router完成网页跳转

展开
这里强化一下编程养成统一的规范,具体可见的JavaScript编程风格

补充:组件都以大写字母开头,文件以小写字母开头,命名方式均采用驼峰式。

接着(二)的新建的应用程序,对于index.js不用修改。我们首先完成路由选择,进行页面的跳转,传统的前端页面使用的链接方式进行跳转,而阵营使用的是路由器。

这里使用的路由器需要本地安装,使用命令:

npm install react-router
之后在app.js中引入反应路由器-DOM,导入编写的界面page1,2,3。

在组件的渲染函数的返回里面,我们可以看到一对<路由器>标签包含了四个<路线>标签,每个<路线>标签中都包含了路径属性和成分属性。

path 属性用于储存路径,就是网站主页路径后面的内容,假如网站地址是localhost:3000,那么,locahost:3000后面的字符串就是路径属性的内容。(注意,路由器只能有一个子组件,所以要把所有路由标签用一个DIV包裹起来)

部件  属性,其中储存了组件名称,当我们访问特定地址时就会渲染该组件,也可以称其为这一个路由的入口组件,可以由这个组件延伸开来搭建页面。

具体实现的代码如下:

import React from 'react';
import { BrowserRouter as Router,Route} from 'react-router-dom';
import Home from './home';
import Page1 from './page1';
import Page2 from './page2';
import Page3 from './page3';
 
class App extends React.Component {
    render(){
        return(
        <Router >
         <div>
            <Route path="/" component={Home} />
            <Route path="/Page1" component={Page1} />                                                                                                                                                                                                                                                                                   
            <Route path="/Page2" component={Page2} />  
            <Route path="/Page3" component={Page3} />                                                                                                                                                                                                                                                                                                                                                                                                                                          
        </div>
        </Router>
        )
 
        }
    }
export default App;
 

Home组件所在路由的路径为“/”,而“/ Page1”开头包含了“/”,React就会默认渲染Home组件。

如果想在访问其他地址时不显示首页组件,可以在首页组件所在路线标签中加入精确:

<Route exact path="/" component={Home} />
首页组件的内容如下(Home.js):

import React from 'react';
 
class Home extends React.Component{
    render(){
        return(
            <div>
            <div>This is Home!</div>
            </div>
        );
    }
}
 
export default Home;
第1页,第3页组件类似,内容为:

import React from 'react';
 
class Page3 extends React.Component{
    render(){
        return(
            <div>
            <div>This is Page3!</div>
            </div>
        );
    }
}
 
export default Page3;
可以对页面增加CSS样式,举个例子:

<div  style={{ fontSize='16px' }}  >This is Page1!</div>
在HTML文件中使用CSS样式,CSS样式分为3种形式:

    1,内联式(行内样式)直接在标签内部声明样式

                <div style =“color:red; font-size:16px”>测试文字</ div>

    2,嵌入式(内部样式)通过标签名,类或id等方法与标签联系起来设置样式

                <style type =“text / css”> div {width:60px; } #mydiv {height:70px} </ style>

    3,外联式(外部样式)通过引入外部文件来设置样式

                <link rel =“stylesheet”type =“text / css”href =“mystyle.css”/>

在反应里,style =后面跟着的是两对大括号,与原本的style =“color:red; font-size:16px”不同。而且样式名称的命名方式也有所不同,由本来的font-size变成了fontSize,采用了单驼峰式的命名形式(前面单词小写,后面单词大写开头)其他的样式名称也用同样的方式来更改,比如用backgroundColor来替代background-color。然后把等号右边的16px加上了引号,作为一个字符串传入。不同样式字段之间用逗号隔开而不是分号。

代码如下:

import React from 'react';
 
class Page1 extends React.Component{
    render(){
        return(
            <div>
                <div
                style={{
                width:'200px',
                height:'80px',
                backgroundColor:'pink',
                fontSize:'24px',
                textAlign:'center'
                }}
                >This is Page1!</div>
            </div>
        );
    }
}
 
export default Page1;
这样,可以看到:



如果想要加入超链接:

import React from 'react';
import { Link } from 'react-router-dom';
 
class Home extends React.Component{
 
    render(){
        return(
            <div>
                <div>This is Home!</div>
                <div>
                <Link to="/Page1/" style={{color:'black'}}>
                <div>点击跳转到Page1</div>
                </Link>
                <Link to="/Page2/" style={{color:'black'}}>
                <div>点击跳转到Page2</div>
                </Link>
                <Link to="/Page3/" style={{color:'black'}}>
                <div>点击跳转到Page3</div>
                </Link>
                </div>
            </div>
        );
    }
}
 
export default Home;
这样可以实现页面的跳转,这里的跳转并没有访问新的HTML文件,而是由作出反应改变了原本的html页面中的内容。



 

附:

CSS样式作为一个对象来引入,该对象的属性就对应着CSS样式属性,创建一个名称为myStyle的的对象:

import React from 'react';
 
class Page1 extends React.Component{
    render(){
        let mystyle={
            width:'200px',
            height:'80px',
            backgroundColor:'pink',
            fontSize:'24px',
            textAlign:'center'
        }
    return(
        <div>
            <div style={mystyle}>This is Page1!</div>
        </div>
        );
    }
}
 
export default Page1;
 

    上面代码中在组件的渲染函数里创建了一个myStyle的对象,属性为CSS样式的内容,在下方标签中的样式属性中引入myStyle的对象(注意,这里只有一层大括号),页面呈现的内容同样使用了CSS样式:

 

      外部导入CSS文件:在同级目录下创建一个mystyle.css文件,内容如下:

#mydiv{
width:200px;
height:80px;
background-color:yellow;
font-size:24px;
text-align:center
}
     去掉Page1组件中定义的样式,并给<div>标签添加id ='mydiv':

import React from 'react';
require('./mystyle.css');
 
class Page1 extends React.Component{
    render(){
        return(
            <div>
                <div id='mydiv'>This is Page1!</div>
            </div>
        );
    }
}
 
export default Page1;
 
————————————————
版权声明:本文为CSDN博主「山鬼谣弋痕夕」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_30363263/article/details/80992288
下载地址:
React学习(五)——向服务器请求数据并显示
React从零开始——一个详细的范例
万事OK自学网:51自学网_软件自学网_CAD自学网自学excel、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。