IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 浏览器中使用react+jsx -> 正文阅读

[JavaScript知识库]浏览器中使用react+jsx

开始学react,先只在浏览器处理,不搞webpack等预处理。

先安装react,我的版本18.1.0:

npm install -g react
npm install -g react-dom

再安装babel,我的版本7.17.11。通天塔,很牛的样子,要把上帝搞乱的语言重新统一起来,负责解析jsx文件:

npm install -g @babel/standalone

写一个like_button.jsx文件:

'use strict';

class LikeButton extends React.Component {
  constructor(props) {
    super(props);
    this.state = { liked: false };
  }

  render() {
    if (this.state.liked) {
      return 'You liked this.';
    }

    return (
      <button onClick={() => this.setState({ liked: true })}>
        Like2
      </button>
    );
  }
}
export default LikeButton;

写一个index.html文件,通过script标签加载like_button.jsx:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <title>Add React in One Minute</title>
  </head>
  <body>

    <h2>Add React in One Minute</h2>
    <p>This page demonstrates using React with no build tooling.</p>
    <p>React is loaded as a script tag.</p>

    <!-- We will put our React component inside this div. -->
    <div id="container"></div>

    <!-- Load React. -->
    <!-- Note: when deploying, replace "development.js" with "production.min.js". -->
    <script src="js/react.development.js"></script>
    <script src="js/react-dom.development.js"></script>
    <script src="js/babel.min.js"></script>

    <script type="text/babel" src="src/like_button.jsx"></script>
    <script type="text/babel">
      const domContainer = document.querySelector('#container');
      const root = ReactDOM.createRoot(domContainer);
      root.render(React.createElement(LikeButton));
    </script>
  </body>
</html>

主要是script标签要加type='text/babel',告诉babel来解析。

如果不用script加载,用import呢,因为有多个jsx文件时,你总想用模组化,而不是一开始就让html把全部jsx文件加载了,试试:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <title>Add React in One Minute</title>
  </head>
  <body>

    <h2>Add React in One Minute</h2>
    <p>This page demonstrates using React with no build tooling.</p>
    <p>React is loaded as a script tag.</p>

    <!-- We will put our React component inside this div. -->
    <div id="container"></div>

    <!-- Load React. -->
    <!-- Note: when deploying, replace "development.js" with "production.min.js". -->
    <script src="js/react.development.js"></script>
    <script src="js/react-dom.development.js"></script>
    <script src="js/babel.min.js"></script>

    <script type="text/babel">
      import LikeButton from './src/like_button.jsx';
      const domContainer = document.querySelector('#container');
      const root = ReactDOM.createRoot(domContainer);
      root.render(React.createElement(LikeButton));
    </script>
  </body>
</html>

报错:Uncaught ReferenceError: require is not defined

看起来是babel加载文件时用到了require函数,给它一个:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <title>Add React in One Minute</title>
  </head>
  <body>

    <h2>Add React in One Minute</h2>
    <p>This page demonstrates using React with no build tooling.</p>
    <p>React is loaded as a script tag.</p>

    <!-- We will put our React component inside this div. -->
    <div id="container"></div>

    <!-- Load React. -->
    <!-- Note: when deploying, replace "development.js" with "production.min.js". -->
    <script src="js/react.development.js"></script>
    <script src="js/react-dom.development.js"></script>
    <script src="js/babel.min.js"></script>
    <script>
      window.require=function(module){
          let xhr = new XMLHttpRequest();
          xhr.open("GET", module, false);
          xhr.send();
          if(xhr.status != 200) {
            throw new Error("require error: http status " + xhr.status);
          }
          //console.log(xhr.responseText);
          //console.log(Babel);
          let code = Babel.transform(xhr.responseText,{presets: ['es2015','react']}).code;
          //console.log(code); 
          let obj=eval(code);
          //console.log(obj);
          return obj;
      }
    </script>
    <script type="text/babel">
      import LikeButton from './src/like_button.jsx';
      const domContainer = document.querySelector('#container');
      const root = ReactDOM.createRoot(domContainer);
      root.render(React.createElement(LikeButton));
    </script>
  </body>
</html>

之前错误没了,报新的错误:Uncaught ReferenceError: exports is not defined

继续hook的方式挂载:

    <script>
      //用hook模式支持jsx文件中的exports
      window.exports = window;
      window.require=function(module){
          let xhr = new XMLHttpRequest();
          xhr.open("GET", module, false);
          xhr.send();
          if(xhr.status != 200) {
            throw new Error("require error: http status " + xhr.status);
          }
          //console.log(xhr.responseText);
          //console.log(Babel);
          let code = Babel.transform(xhr.responseText,{presets: ['es2015','react']}).code;
          //console.log(code); 
          let obj=eval(code);
          //console.log(obj);
          return obj;
      }
    </script>

ok,可以了。

require要求同步方法,应该没办法用浏览器的fetch函数?

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章           查看所有文章
加:2022-05-19 11:53:09  更:2022-05-19 11:55:01 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 9:03:26-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码