在 HTML 页面中使用 React的场景分析


Posted in Javascript onJanuary 18, 2022

该方案使用场景:在html页面中使用react,主js文件index.js和其它非react功能使用js模块化的方式开发,适合轻量级中小型应用

index.html代码:

引入react、react-dom、babel、moment、antd等

<!DOCTYPE html>
<html lang='zh-CN'>

<head>
    <title>React in HTML</title>

    <meta charset="utf-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">

    <link rel="stylesheet" href="libs/antd/antd.min.css">
    <link rel="stylesheet" href="css/index.css">

    <style type="text/css">

    </style>

    <script type="text/javascript" src="libs/jquery-1.9.1.js"></script>

    <script type="text/javascript" src="libs/react/react.production.min.js"></script>
    <script type="text/javascript" src="libs/react/react-dom.production.min.js"></script>
    <script type="text/javascript" src="libs/babel/babel.min.js"></script>
    <script type="text/javascript" src="libs/moment/moment-with-locales.min.js"></script>
    <script type="text/javascript" src="libs/antd/antd-with-locales.min.js"></script>

</head>

<body>
    <input id='btn' type="button" class="index-btn" value="显示React组件" />

    <script type="text/babel" src="components/HelloReact.jsx"></script>

    <script type="module" src="index.js"></script>
</body>

</html>

index.js代码:

import { ReactComponentContainer } from './ReactComponentContainer.js'

let isShow = true;
let helloReactContainer;

$('#btn').on('click', function () {
    if (isShow) {
        helloReactContainer = new ReactComponentContainer('helloReact', HelloReact, { name: 'React' });
        helloReactContainer.show();
        isShow = false;
        $(this).val('隐藏React组件');
    } else {
        helloReactContainer.hide();
        isShow = true;
        $(this).val('显示React组件');
    }
});

ReactComponentContainer.js代码:

该模块用于在html中显示隐藏react组件

class ReactComponentContainer {

    component
    componentProps
    componentContainerId

    constructor(componentContainerId, component, componentProps) {
        if ($('#' + componentContainerId).length == 0) {
            $('body').append('<div id="' + componentContainerId + '"></div>');
        }

        this.componentContainerId = componentContainerId;
        this.component = component;
        this.componentProps = componentProps;
    }

    render(isShow) {
        ReactDOM.render(
            React.createElement(
                antd.ConfigProvider,
                {
                    locale: antd.locales.zh_CN
                },
                React.createElement(this.component, Object.assign({ isShow: isShow }, this.componentProps))
            ),
            document.getElementById(this.componentContainerId)
        );
    }

    show() {
        this.render(true);
    }

    hide() {
        this.render(false);
    }

}

export { ReactComponentContainer }

HelloReact.jsx代码:

class HelloReact extends React.Component {
    dateFormat = 'YYYY-MM-DD'
    timeFormat = 'HH:mm:ss'

    constructor(props) {
        super(props);

        let now = new Date().valueOf();

        this.state = {
            dateStr: moment(now).format(this.dateFormat),
            timeStr: moment(now).format(this.timeFormat)
        }

        this.onChangeDate = this.onChangeDate.bind(this);
        this.onChangeTime = this.onChangeTime.bind(this);
        this.updateDatePickerAndTimePicker = this.updateDatePickerAndTimePicker.bind(this);
    }

    onChangeDate(date, dateString) {
        this.setState({ dateStr: dateString });
    }

    onChangeTime(time, timeString) {
        this.setState({ timeStr: timeString });
    }

    updateDatePickerAndTimePicker() {
        let now = new Date().valueOf();
        this.setState({
            dateStr: moment(now).format(this.dateFormat),
            timeStr: moment(now).format(this.timeFormat)
        });
    }

    render() {
        return <div style={{ display: this.props.isShow ? '' : 'none' }}>
            <h1>Hello {this.props.name}, Now is {this.state.dateStr} {this.state.timeStr}</h1>
            <antd.DatePicker onChange={this.onChangeDate} value={moment(this.state.dateStr, this.dateFormat)} />
             
            <antd.TimePicker onChange={this.onChangeTime} value={moment(this.state.timeStr, this.timeFormat)} />
            <br />
            <antd.Button type="primary" size="default" style={{ marginTop: '10px' }} onClick={this.updateDatePickerAndTimePicker} >更新日期时间控件值</antd.Button>
        </div>;
    }
}

效果图:

在 HTML 页面中使用 React的场景分析

浏览器按F12弹出DevTools,在Sources选项卡中可以看到组件代码,方便打断点调试

在 HTML 页面中使用 React的场景分析

遇到的问题:

无法使用es6的import语法导入react组件,es6的import和require.js都不认识jsx

react组件不是按需加载,只适合小型应用

Gitee代码地址:

https://gitee.com/s0611163/react-in-html

到此这篇关于在 HTML 页面中使用 React的文章就介绍到这了,更多相关html使用react内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

 
Javascript 相关文章推荐
jquery 可排列的表实现代码
Nov 13 Javascript
js判断滚动条是否已到页面最底部或顶部实例
Nov 20 Javascript
js实现单击图片放大图片的方法
Feb 17 Javascript
BootStrap实用代码片段之一
Mar 22 Javascript
JavaScript中Form表单技术汇总(推荐)
Jun 26 Javascript
AngularJS ng-app 指令实例详解
Jul 30 Javascript
微信小程序 教程之wxapp 视图容器 view
Oct 19 Javascript
Agularjs妙用双向数据绑定实现手风琴效果
May 26 Javascript
js学习心得_一个简单的动画库封装tween.js
Jul 14 Javascript
JS实现checkbox互斥(单选)功能示例
May 04 Javascript
微信小程序封装的HTTP请求示例【附升级版】
May 11 Javascript
JS获取当前时间的年月日时分秒及时间的格式化的方法
Dec 18 Javascript
Element-ui Layout布局(Row和Col组件)的实现
Dec 06 #Vue.js
浅谈JavaScript作用域
Dec 06 #Javascript
JavaScript流程控制(循环)
Dec 06 #Javascript
JavaScript流程控制(分支)
Dec 06 #Javascript
JavaScript实现队列结构过程
Dec 06 #Javascript
JavaScript实现栈结构详细过程
Dec 06 #Javascript
JavaScript实现优先级队列
Dec 06 #Javascript
You might like
php高性能日志系统 seaslog 的安装与使用方法分析
2020/02/29 PHP
slice函数的用法 之不错的应用
2006/12/29 Javascript
网上抓的一个特效
2007/05/11 Javascript
jQuery Ajax 全解析
2009/02/08 Javascript
Javascript表格翻页效果实现思路及代码
2013/08/23 Javascript
js中this用法实例详解
2015/05/05 Javascript
jQuery实现图片轮播特效代码分享
2015/09/15 Javascript
JS实现兼容性好,自动置顶的淘宝悬浮工具栏效果
2015/09/18 Javascript
uploadify多文件上传参数设置技巧
2015/11/16 Javascript
Vue不能检测到Object/Array更新的情况的解决
2018/06/26 Javascript
Vue 配合eiement动态路由,权限验证的方法
2018/09/26 Javascript
vue-cli 3.0 版本与3.0以下版本在搭建项目时的区别详解
2018/12/11 Javascript
JavaScript使用闭包模仿块级作用域操作示例
2019/01/21 Javascript
小程序异步问题之多个网络请求依次执行并依次收集请求结果
2019/05/05 Javascript
Vue 设置axios请求格式为form-data的操作步骤
2019/10/29 Javascript
js中apply和call的理解与使用方法
2019/11/27 Javascript
[01:02:46]VGJ.S vs NB 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
python文件写入实例分析
2015/04/08 Python
Python文件读取的3种方法及路径转义
2015/06/21 Python
Python数据结构与算法之常见的分配排序法示例【桶排序与基数排序】
2017/12/15 Python
解决Python下json.loads()中文字符出错的问题
2018/12/19 Python
python中的decimal类型转换实例详解
2019/06/26 Python
从pandas一个单元格的字符串中提取字符串方式
2019/12/17 Python
在服务器上安装python3.8.2环境的教程详解
2020/04/26 Python
Keras中的两种模型:Sequential和Model用法
2020/06/27 Python
使用Python文件读写,自定义分隔符(custom delimiter)
2020/07/05 Python
Python延迟绑定问题原理及解决方案
2020/08/04 Python
世界最大的私人旅行指南出版商:孤独星球
2016/08/23 全球购物
玩具反斗城天猫官方旗舰店:享誉全球的玩具店
2017/10/10 全球购物
浙大毕业生自荐信
2014/01/26 职场文书
中学教师暑期培训方案
2014/08/27 职场文书
如何让vue长列表快速加载
2021/03/29 Vue.js
浅谈Java实现分布式事务的三种方案
2021/06/11 Java/Android
Nginx实现负载均衡的项目实践
2022/03/18 Servers
Python&Matlab实现樱花的绘制
2022/04/07 Python
Android移动应用开发指南之六种布局详解
2022/09/23 Java/Android