react typescript component strongly
[React Typescript] Extracting Props from Custom Components
// Imagine NavBar is an external library! export const NavBar = (props: { title: string; links: string[]; children: React.ReactNode; }) => { return <d ......
[React Typescript] Overriding and Removing Component Props
Using Omit import { ComponentProps } from 'react'; import { Equal, Expect } from '../helpers/type-utils'; export const Input = ( props: Omit<Component ......
[React Typescript] Useful React Prop Type Examples
Relevant for components that accept other React components as props. export declare interface AppProps { children?: React.ReactNode; // best, accepts ......
使用VUE的component is 组件实现切换标签
VUE实现切换标签: <!DOCTYPE html> <html> <head> <title>Dynamic Components Example</title> <script src="https://unpkg.com/vue@2"></script> <style> .tab-button ......
使用 React Three Fiber 和 GSAP 实现 WebGL 轮播动画
参考:[Building a WebGL Carousel with React Three Fiber and GSAP](https://tympanus.net/codrops/2023/04/27/building-a-webgl-carousel-with-react-three-fibe ......
图文并茂15分钟教你快速入门React
# React 是什么 ### 简介 - 用于构建 Web 和原生交互界面的库 - React 用组件创建用户界面 - 通俗来讲:==是一个将数据渲染为HTML视图的开源JS库== ### 其他信息 - Facebook 开发,并且开源 # 为什么使用React? - 原生JS使用DOM-API修改 ......
react-create-app 创建的项目添加保存自动格式化
## 前言 首先, react-create-app 创建的项目是自带安装eslint的, 所以我们要安装prettier 及相关插件 参考 => https://juejin.cn/post/6844903901544742925 ## 安装的包 这些都是开发时依赖, 注意安装位置 ### esl ......
[React] useEffect
#### pure function:单纯返回jsx元素的组件 在使用react函数组件时,理论上函数组件只会进行不改变内部状态值的计算,以及返回html代码。一个pure函数就是如此,例如一个函数组件接受一个id作为传入属性,注意这里传入的id并没有发生变化,我们只是简单进行了输出和数学计算: ` ......
TypeScript 如何自己实现一个Promise
import {readFile} from 'fs'; type Resolve<T> = (result: T) => void; type Reject = (error: unknown) => void; type Executor<T> = ( resolve: Resolve<T>, ......
React闭包陷阱
# React闭包陷阱 `React Hooks`是`React 16.8`引入的一个新特性,其出现让`React`的函数组件也能够拥有状态和生命周期方法,其优势在于可以让我们在不编写类组件的情况下,更细粒度地复用状态逻辑和副作用代码,但是同时也带来了额外的心智负担,闭包陷阱就是其中之一。 ## 闭 ......
React 源码调试 (react版本17.0.2)
环境准备 // create-react-a匹配版本 $ create-react-app -V 5.0.1 // node 版本 $ node -V v16.16.0 1、第一步 通过 create-react-app 快速创建环境,然后运行 yarn eject 释放webpack配置 npx ......
1. react项目【前端】+C#【后端】从0到1
1、创建前端基础框架 1.1 前端创建 软件: 1.1.1 npx create-react-app pc ps:pc 是文件名 ; 1.1.2 npm start 启动项目 2、创建后端基础框架 软件: 2.1 创建 webapi 项目 Program.cs 是启动文件 ; ......
React.FC中父组件调用子组件方法
https://blog.csdn.net/qq_36990322/article/details/109858890 1. 函数式和hooks写法 其实下面的缺点基本不算缺点了,因为函数式写法,下面算是简单的了。使用forwardRef只会让你的组件定义的更复杂 优点:1、写法简单易懂2、假如子组 ......
创建react中 函数请求叠加只会请求一次 和 对象销毁后中断接口回调的方法
// 关于接口请求方法重复运行的问题 确保每次接口返回的都是最后一次请求执行 export const SingleAction = function(Action: (...param:any)=> Promise<any>){ // 创建唯一值 let AccessNewTime: number ......
webpack基础配置代码-react
1.webpack.config.js // nodejs中的核心模块,用来处理路径 const path = require("path"); // eslint 检查js文件规范 const ESLintWebpackPlugin = require("eslint-webpack-plugin ......
部署带路由的React SPA 项目
使用 Nginx 将 /phone/* 请求反向代理为 /* 启动项目 serve -s ./build -l 3000 项目内路由仍然是 /phone/xxx 不用改动, 但需要在 package.json 中, 指定静态资源根目录 { ... "homepage": "/phone/", ... ......
TypeScript中的定时器
在ts中使用setInterval()和 setTimeout()时,如果把特们的返回值定义成number类型,那么ts会警告你不能将类型“Timeout”分配给类型“number” 或 你不能将类型“Timer”分配给类型“number” 原因 setInterval()和 setTimeout( ......
【React】react-json-view用法
react-json-view: 前端json可视化插件 安装: npm install --save react-json-view 使用: import ReactJson from 'react-json-view' <ReactJson/> 配置: <ReactJson collapsed= ......
【React+Antd】 多选下拉框禁止输入
<Select options={} onChange={provinceChange} allowClear mode="multiple"// showSearch={false} maxTagTextLength={4} /> mode设置为多选,multiple配合showSearch可以实 ......
【React】格式化中国标准时间
//定义格式化函数: handleTime(time, format) { if (time == null || time == undefined || time == "") { return ""; } var t = new Date(time); var tf = function (i ......
【React】自定义水印方法
创建水印方法: const setWaterwark = ({ // 使用 ES6 的函数默认值方式设置参数的默认取值 container = document.body, width = '250px', height = '160px', textAlign = 'left', textBase ......
【React】视频播放器,ReactPlayer的使用
import React from 'react'; import ReactPlayer from 'react-player'//引入 const LiveBroadcast=()=>{ return<ReactPlayer className='react-player' url='....f ......
【React+Antd】 可展开Table
在antd基础上进行改造,抛弃之前的靠前面+进行展开的方式,在操作列进行点击展开 import { Table } from 'antd'; import React,{useState} from 'react'; import 'antd/dist/antd.css'; import './in ......
企业级项目模板的配置与集成(Vite + Vue3 + TypeScript)
企业级项目模板的配置与集成(Vite + Vue3 + TypeScript) 1、项目介绍 项目使用:eslint + stylelint + prettier来对我们代码质量做检测和修复。 需要使用husky来做commit拦截 需要使用commitlint来统一提交规范 需要使用preinst ......
【React+Antd】可编辑表格
import React, { useContext, useState, useEffect, useRef } from "react"; import { Table, Input, Button, Popconfirm, Form } from "antd"; const EditableC ......
【React】定时器组件
鼠标移入关闭定时器并清除,鼠标移出组件的时候打开定时器进行循环 const timer = useRef(null); useEffect(() => { startLoop(); }, []); const startLoop = () => { stopLoop(); timer.current ......
【React+Antd】表格增删改
Modal弹框进行增改,删除直接用filter进行删除 添加: 1 setTabledate([...tabledate, newD]); 删除: setTabledate(tabledate.filter((item) => item.key !== record.key)); 修改: const ......
从0到1无比流畅的React入门教程
无比流畅的React入门教程(无比流畅的React入门教程) React 是什么 简介 用于构建 Web 和原生交互界面的库 React 用组件创建用户界面 通俗来讲:==是一个将数据渲染为HTML视图的开源JS库== 其他信息 Facebook 开发,并且开源 为什么使用React? 原生JS使用 ......
从0到1搭建后台管理系统(Vue3 + Vite4 + TypeScript + Element Plus + Pinia + Vue Router )
参考有来:https://www.cnblogs.com/haoxianrui/p/17331952.html Node 16+ 版本大于16【问题一:目前我是14.18.2的版本npm是6.14.15版本,这就涉及到要切换node版本的问题,不然我安装了16我的vue2项目就启动不了了】 vsco ......
React笔记-生命周期(七)
React笔记-生命周期(七) 生命周期值React组件从装载到卸载的全过程 在这个过程中React提供了多个内置函数供开发者在不同阶段执行需要的逻辑 状态组件由3个阶段组成 挂载阶段(MOUNTING) 更新阶段(UPDATING) 卸载阶段(UNMOUNT) 从纵向划分为2个阶段 Render阶 ......