首页
学习
活动
专区
圈层
工具
发布

使用Sqlite3+Express.js+React实现在线答题(下)

在使用Sqlite3+Express.js+React实现在线答题(上)中,我们将题目数据从word文件转为txt格式并导入到sqlite3中,使用Express.js建立了json数据API接口。...本篇文章我们将使用ReactJS建立前端。 建立React项目 首先安装create-react-app,如果你已安装,请略过。...2018-01-31 13-49-01屏幕截图.png 从服务器获取json数据我们需要用jquery,安装 npm install query 界面设计 我们预想的操作界面是这样的(原谅我粗狂的画风^...导入 import React, { Component } from 'react'; import $ from 'jquery'; import '....'checkbox' : 'radio'; // 多选题使用checkbox,单选题使用radio,注意判断题也是单选 var selection_name = this.props.reamrk

3.5K20

如何在已有的 Web 应用中使用 ReactJS

所以,如果你的代码是用 jQuery 或者其它框架所写,那么应该如何使用 React 去替换这些 UI 片段?...如果代码库使用 jQuery,通常会有一个元素充当 wrapper 选择器。使用 jQuery 选择 wrapper 元素,它被用于动态更新 DOM。 使用 jQuery 更改 DOM 的唯一策略,但很常见。...用 jQuery 实现共享状态 使用 jQuery 可以很容易实现,但是,如果一个区域动态影响另一个单独使用选择器的区域时,可能会变得混乱。...主要的解决方法就是,如果你使用 jQuery 处理 UI 片段,那么你可以将容器元素替换成一个 React 组件。如果你需要在多个组件中分享状态,那么你可以使用容器方法或者类似 Redux 的库。

16.7K00
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    如何在现有的 Web 应用中使用 ReactJS

    所以,如果你的代码是用 jQuery 或者其它框架所写,那么应该如何使用 React 去替换这些 UI 片段?...如果代码库使用 jQuery,通常会有一个元素充当 wrapper 选择器。使用 jQuery 选择 wrapper 元素,它被用于动态更新 DOM。 使用 jQuery 更改 DOM 的唯一策略,但很常见。...用 jQuery 实现共享状态 使用 jQuery 可以很容易实现,但是,如果一个区域动态影响另一个单独使用选择器的区域时,可能会变得混乱。...主要的解决方法就是,如果你使用 jQuery 处理 UI 片段,那么你可以将容器元素替换成一个 React 组件。如果你需要在多个组件中分享状态,那么你可以使用容器方法或者类似 Redux 的库。

    10.1K40

    受控组件和非受控组件

    您为表单字段提供了一个没有onChange处理程序的value属性,这将呈现只读字段,如果字段应该是可变的,请使用defaultValue,否则请设置onChange或readOnly。...这段Warning其实给出了对于这个问题的解决方案,我们只需要对组件的onChange事件来监听输入内容的改变并使用setState更新this.state.username即可,如此我们在当前组件中能够控制这个表单元素的值...,是有弊端的,尽管此时Input组件本身是一个受控组件,但与之相对的调用方失去了更改Input组件值的控制权,所以对调用方而言,Input组件是一个非受控组件,以非受控组件的使用方式去调用受控组件是一种反模式...react受控组件更新state的流程: 通过在初始state中设置表单的默认值。 每当表单的值发生变化时,调用onChange事件处理器。...SetState触发视图的重新渲染,完成表单组件值的更新。 非受控组件 如果一个表单组件没有value prop就可以称为非受控组件。

    2.1K10

    快速上手三大基础 React Hooks

    在父组件中调用,通过 props 传递 initialState 初始化值 用 useState 方法替换掉原有的 class 不仅性能会有所提升,而且可以看到代码量减少很多,并且不再需要使用 this...useEffect useEffect 是专门用来处理副作用的,获取数据、创建订阅、手动更改 DOM 等这都是副作用。...然后创建获取数据的 getData 方法 创建事件处理函数 handleClick 使用 useEffect 处理副作用:改变页面的 title 如果使用传统的类组件的写法: 1import React...第一次渲染和每次更新之后都会触发这个钩子,如果需要手动修改自定义触发规则 见文档:https://zh-hans.reactjs.org/docs/hooks-effect.html#tip-optimizing-performance-by-skipping-effects...可以使用也可以不使用: 20190313113753.png 文档:https://zh-hans.reactjs.org/docs/hooks-effect.html#recap 比方说我们使用 useEffect

    1.8K40

    40道ReactJS 面试问题及答案

    当处理接收相同道具但不需要在每次更改时重新渲染的功能组件时,这尤其有用。 另外,如果组件很轻并且使用多个 props 渲染,请避免使用 React Memo。...非受控组件:在非受控组件中,表单数据由 DOM 本身处理,React 不通过状态控制输入值。 输入值由 DOM 管理,通常在需要时使用 ref 来访问输入值。...受控组件:表单数据由 React 组件(而不是 DOM)处理,方法是将输入值存储在状态中,并在输入更改时更新状态。 输入值由 React 状态控制,输入的更改通过事件处理程序进行处理,从而更新状态。...如果类组件定义了生命周期方法 static getDerivedStateFromError() 或 componentDidCatch() 中的一个(或两个),则该类组件将成为错误边界。...在后续测试运行中,它将当前输出与存储的快照进行比较,如果存在任何差异,则测试失败。

    8.3K10

    开始学习React js

    对于React而言,则完全是一个新的思路,开发者从功能的角度出发,将UI分成不同的组件,每个组件都独立封装。...如果一个组件内部创建了另一个组件,那么说父组件拥有(own)它创建的子组件,通过这个特性,一个复杂的UI可以拆分成多个简单的UI组件; (2)可重用(Reusable):每个组件都是具有独立功能的,它可以被使用在多个...这里需要注意的是,react并不依赖jQuery,当然我们可以使用jQuery,但是render里面第二个参数必须使用JavaScript原生的getElementByID方法,不能使用jQuery来选取...通过这个例子来理解ReactJS的状态机制。先看代码: ? 这里,我们又使用到了一个方法getInitialState,这个函数在组件初始化的时候执行,必需返回NULL或者一个对象。...这里我们可以通过this.state.属性名来访问属性值,这里我们将enable这个值跟input的disabled绑定,当要修改这个属性值时,要使用setState方法。

    9.3K60

    【整合】input标签JS改变Value事件处理方法

    实现的效果:   1、文本框支持手工输入,通过用户输入修改值,手工输入结束后触发事件。阻塞在于失去焦点后才触发(输入过程中不触发事件)   2、通过JS方法修改值,修改后触发事件。...这样onpropertychange就对手工输入无效;   3、实现手工输入结束后要触发事件,使用onchange事件   1、其他浏览器中也可以使用onchange模拟输入结束后触发事件,但是没法使用...使用定时器模拟效果 <!...:-D         或者是Jquery的锅?...Value),任何变化都会触发事件,包括适用JS操作       适用场景为:页面运行期间实时监听元素属性变化,触发事件,特别适用于在IE中JS操作触发事件的场景 后记:项目原需求的实现其实最好是在控件里面更改

    14K50

    一看就懂的ReactJs入门教程(精华版)

    对于React而言,则完全是一个新的思路,开发者从功能的角度出发,将UI分成不同的组件,每个组件都独立封装。...如果一个组件内部创建了另一个组件,那么说父组件拥有(own)它创建的子组件,通过这个特性,一个复杂的UI可以拆分成多个简单的UI组件; (2)可重用(Reusable):每个组件都是具有独立功能的,它可以被使用在多个...下面我们在script标签里面编写代码,来输出Hello,world,代码如下: 这里需要注意的是,react并不依赖jQuery,当然我们可以使用jQuery,但是render里面第二个参数必须使用JavaScript...原生的getElementByID方法,不能使用jQuery来选取DOM节点。...这里我们可以通过this.state.属性名来访问属性值,这里我们将enable这个值跟input的disabled绑定,当要修改这个属性值时,要使用setState方法。

    10.7K80

    React 系列教程 1:实现 Animate.css 官网效果

    对于 Animate.css 官网效果是一个非常简单的例子,原代码使用 jQuery 编写,就是添加类与删除类的操作。...开始吧 编写 HTML 结构 整个教程采用 ES6 语法编写,无法直接在浏览器预览,所以需要使用 Babel 编译一下,大家可以使用官方的 create-react-app 脚手架搭建开发环境。...关于状态 React 和 jQuery(传统前端编程)的最大不同在于 DOM 操作的方式,React 通过状态变化来更新 DOM,而传统方式则使用事件更新 DOM。...上一篇文章《如何在已有的 Web 应用中使用 ReactJS》通过更简单的示例介绍了 React 和 jQuery 的不同之处,感兴趣的同学可以详细了解一下。...${this.state.selected}`} onAnimationEnd={this.handleAnimationEnd}>Animate.css onChange

    2K20

    React 系列教程 1:实现 Animate.css 官网效果

    对于 Animate.css 官网效果是一个非常简单的例子,原代码使用 jQuery 编写,就是添加类与删除类的操作。...开始吧 编写 HTML 结构 整个教程采用 ES6 语法编写,无法直接在浏览器预览,所以需要使用 Babel 编译一下,大家可以使用官方的 create-react-app 脚手架搭建开发环境。...关于状态 React 和 jQuery(传统前端编程)的最大不同在于 DOM 操作的方式,React 通过状态变化来更新 DOM,而传统方式则使用事件更新 DOM。...上一篇文章《如何在已有的 Web 应用中使用 ReactJS》通过更简单的示例介绍了 React 和 jQuery 的不同之处,感兴趣的同学可以详细了解一下。...${this.state.selected}`} onAnimationEnd={this.handleAnimationEnd}>Animate.css onChange

    2.1K00

    React学习(四)-理清React的工作方式

    /3.4.1/jquery.js"> function handleClick(flag) { var...最重要的是区分哪些是属于data,哪些是属于render,想要更新用户界面,要做的是更新data,用户的界面自然会做出响应,所以把React称为响应式编程(面向数据编程) 注意:render函数返回的值,...也就是说, 这样的写法是不起作用的 如果想要在组件标签上监听事件起作用,也可以做到,就是结合第三方模块styled-components样式组件进行使用,是可以做到的...就让页面显示什么,无需关注DOM操作,并且React引入了虚拟DOM 它是对DOM树的一种抽象,本质上就是一js对象,当进行视图的改变时,当React的子元素内容发生改变时,并不会引起整个浏览器的重绘和重排,只会更改变化的数据部分...,并且在给JSX添加事件监听时,使用on*EnentType的方式 并且这种事件的监听,它只作用于原生HTML元素上,若放在自定义的组件上时,是不起作用的,具体解决办法,可以引入第三方styled-components

    2.3K30
    领券