dva.js 知识导图

JavaScript 语言
变量声明
const 和 let
模板字符串
默认参数
箭头函数
模块的 Import 和 Export
ES6 对象和数组
析构赋值
对象字面量改进
Spread Operator
Promises
Generators
React Component
Stateless Functional Components
JSX
Component 嵌套
className
JavaScript 表达式
Mapping Arrays to JSX
注释
Spread Attributes
Props
propTypes
往下传数据
往上传数据
CSS Modules
理解 CSS Modules
定义全局 CSS
classnames Package
Reducer
增删改
嵌套数据的增删改
Effect
Effects
put
call
select
错误处理
全局错误处理
本地错误处理
异步请求
GET 和 POST
统一错误处理
Subscription
异步数据初始化
path-to-regexp Package
Router
Config with JSX Element (router.js)
Route Components
通过 connect 绑定数据
Injected Props (e.g. location)
基于 action 进行页面跳转
dva 配置
Redux Middleware
history
切换 history 为 browserHistory
去除 hashHistory 下的 _k 查询参数
工具
通过 dva-cli 创建项目

JavaScript 语言

变量声明
const 和 let
不要用 var,而是用 const 和 let,分别表示常量和变量。不同于 var 的函数作用域,const 和 let 都是块级作用域。

const DELAY = 1000;let count = 0;
count = count + 1;

模板字符串
模板字符串提供了另一种做字符串组合的方法。

const user = 'world';
console.log(`hello ${user}`);  // hello world// 多行
const content = `Hello ${firstName},Thanks for ordering ${qty} tickets to ${event}.
`;
默认参数
function logActivity(activity = 'skiing') {console.log(activity);
}logActivity();  // skiing

箭头函数
函数的快捷写法,不需要通过 function 关键字创建函数,并且还可以省略 return 关键字。

同时,箭头函数还会继承当前上下文的 this 关键字。

比如:

[1, 2, 3].map(x => x + 1);  // [2, 3, 4]
等同于:[1, 2, 3].map((function(x) {return x + 1;
}).bind(this));

模块的 Import 和 Export
import 用于引入模块,export 用于导出模块。

比如:

// 引入全部
import dva from 'dva';// 引入部分
import { connect } from 'dva';
import { Link, Route } from 'dva/router';// 引入全部并作为 github 对象
import * as github from './services/github';// 导出默认
export default App;
// 部分导出,需 import { App } from './file'; 引入
export class App extend Component {};

ES6 对象和数组
析构赋值
析构赋值让我们从 Object 或 Array 里取部分数据存为变量。

// 对象
const user = { name: 'guanguan', age: 2 };
const { name, age } = user;
console.log(`${name} : ${age}`);  // guanguan : 2

// 数组

const arr = [1, 2];
const [foo, bar] = arr;
console.log(foo);  // 1

我们也可以析构传入的函数参数。

const add = (state, { payload }) => {return state.concat(payload);
};

析构时还可以配 alias,让代码更具有语义。

const add = (state, { payload: todo }) => {return state.concat(todo);
};

对象字面量改进
这是析构的反向操作,用于重新组织一个 Object 。

const name = 'duoduo';
const age = 8;const user = { name, age }; // { name: 'duoduo', age: 8 }

定义对象方法时,还可以省去 function 关键字。

app.model({reducers: {add() {}  // 等同于 add: function() {}},effects: {*addRemote() {}  // 等同于 addRemote: function*() {}},
});
Spread Operator
Spread Operator 即 3 个点 ...,有几种不同的使用方法。

可用于组装数组。

const todos = ['Learn dva'];
[...todos, 'Learn antd']; // ['Learn dva', 'Learn antd']

也可用于获取数组的部分项。

const arr = ['a', 'b', 'c'];
const [first, ...rest] = arr;
rest;  // ['b', 'c']// With ignore
const [first, , ...rest] = arr;
rest;  // ['c']

还可收集函数参数为数组。

function directions(first, ...rest) {console.log(rest);
}
directions('a', 'b', 'c');  // ['b', 'c'];

代替 apply。

function foo(x, y, z) {}
const args = [1,2,3];
// 下面两句效果相同
foo.apply(null, args);
foo(...args);

对于 Object 而言,用于组合成新的 Object 。

const foo = {a: 1,b: 2,
};
const bar = {b: 3,c: 2,
};
const d = 4;const ret = { ...foo, ...bar, d }; // { a:1, b:3, c:2, d:4 }

此外,在 JSX 中 Spread Operator 还可用于扩展 props,详见 Spread Attributes。

Promises
Promise 用于更优雅地处理异步请求。比如发起异步请求:

fetch('/api/todos').then(res => res.json()).then(data => ({ data })).catch(err => ({ err }));
定义 Promise 。const delay = (timeout) => {return new Promise(resolve => {setTimeout(resolve, timeout);});
};delay(1000).then(_ => {console.log('executed');
});

Generators
dva 的 effects 是通过 generator 组织的。Generator 返回的是迭代器,通过 yield 关键字实现暂停功能。

这是一个典型的 dva effect,通过 yield 把异步逻辑通过同步的方式组织起来。

app.model({namespace: 'todos',effects: {*addRemote({ payload: todo }, { put, call }) {yield call(addTodo, todo);yield put({ type: 'add', payload: todo });},},
});

React Component
Stateless Functional Components
React Component 有 3 种定义方式,分别是 React.createClass, class 和 Stateless Functional Component。推荐尽量使用最后一种,保持简洁和无状态。这是函数,不是 Object,没有 this 作用域,是 pure function。

比如定义 App Component 。

function App(props) {function handleClick() {props.dispatch({ type: 'app/create' });}return <div onClick={handleClick}>${props.name}</div>
}

等同于:

class App extends React.Component {handleClick() {this.props.dispatch({ type: 'app/create' });}render() {return <div onClick={this.handleClick.bind(this)}>${this.props.name}</div>}
}

JSX
Component 嵌套
类似 HTML,JSX 里可以给组件添加子组件。

<App><Header /><MainContent /><Footer />
</App>

className
class 是保留词,所以添加样式时,需用 className 代替 class 。

<h1 className="fancy">Hello dva</h1>

JavaScript 表达式
JavaScript 表达式需要用 {} 括起来,会执行并返回结果。

比如:

<h1>{ this.props.title }</h1>
Mapping Arrays to JSX

可以把数组映射为 JSX 元素列表。

<ul>{ this.props.todos.map((todo, i) => <li key={i}>{todo}</li>) }
</ul>

注释

尽量别用 // 做单行注释。

<h1>{/* multiline comment */}{/*multilinecomment*/}{// single line}Hello
</h1>

Spread Attributes
这是 JSX 从 ECMAScript6 借鉴过来的很有用的特性,用于扩充组件 props 。

比如:

const attrs = {href: 'http://example.org',target: '_blank',
};
<a {...attrs}>Hello</a>

等同于

const attrs = {href: 'http://example.org',target: '_blank',
};
<a href={attrs.href} target={attrs.target}>Hello</a>

Props
数据处理在 React 中是非常重要的概念之一,分别可以通过 props, state 和 context 来处理数据。而在 dva 应用里,你只需关心 props 。

propTypes
JavaScript 是弱类型语言,所以请尽量声明 propTypes 对 props 进行校验,以减少不必要的问题。

function App(props) {return <div>{props.name}</div>;
}
App.propTypes = {name: React.PropTypes.string.isRequired,
};

内置的 prop type 有:

PropTypes.array
PropTypes.bool
PropTypes.func
PropTypes.number
PropTypes.object
PropTypes.string

往下传数据
在这里插入图片描述

往上传数据

在这里插入图片描述

CSS Modules

在这里插入图片描述

理解 CSS Modules
一张图理解 CSS Modules 的工作原理:

在这里插入图片描述

button class 在构建之后会被重命名为 ProductList_button_1FU0u 。button 是 local name,而 ProductList_button_1FU0u 是 global name 。你可以用简短的描述性名字,而不需要关心命名冲突问题。

然后你要做的全部事情就是在 css/less 文件里写 .button {…},并在组件里通过 styles.button 来引用他。

定义全局 CSS
CSS Modules 默认是局部作用域的,想要声明一个全局规则,可用 :global 语法。

比如:

.title {color: red;
}
:global(.title) {color: green;
}

然后在引用的时候:

<App className={styles.title} /> // red
<App className="title" />        // green

classnames Package
在一些复杂的场景中,一个元素可能对应多个 className,而每个 className 又基于一些条件来决定是否出现。这时,classnames 这个库就非常有用。

import classnames from 'classnames';
const App = (props) => {const cls = classnames({btn: true,btnLarge: props.type === 'submit',btnSmall: props.type === 'edit',});return <div className={ cls } />;
}

这样,传入不同的 type 给 App 组件,就会返回不同的 className 组合:

<App type="submit" /> // btn btnLarge
<App type="edit" />   // btn btnSmall

Reducer
reducer 是一个函数,接受 state 和 action,返回老的或新的 state 。即:(state, action) => state
增删改
以 todos 为例。

app.model({namespace: 'todos',state: [],reducers: {add(state, { payload: todo }) {return state.concat(todo);},remove(state, { payload: id }) {return state.filter(todo => todo.id !== id);},update(state, { payload: updatedTodo }) {return state.map(todo => {if (todo.id === updatedTodo.id) {return { ...todo, ...updatedTodo };} else {return todo;}});},},
};

嵌套数据的增删改
建议最多一层嵌套,以保持 state 的扁平化,深层嵌套会让 reducer 很难写和难以维护。

app.model({namespace: 'app',state: {todos: [],loading: false,},reducers: {add(state, { payload: todo }) {const todos = state.todos.concat(todo);return { ...state, todos };},},
});

下面是深层嵌套的例子,应尽量避免。

app.model({namespace: 'app',state: {a: {b: {todos: [],loading: false,},},},reducers: {add(state, { payload: todo }) {const todos = state.a.b.todos.concat(todo);const b = { ...state.a.b, todos };const a = { ...state.a, b };return { ...state, a };},},
});

Effect
示例:

app.model({namespace: 'todos',effects: {*addRemote({ payload: todo }, { put, call }) {yield call(addTodo, todo);yield put({ type: 'add', payload: todo });},},
});

Effects
put
用于触发 action 。

yield put({ type: 'todos/add', payload: 'Learn Dva' });

call
用于调用异步逻辑,支持 promise 。

const result = yield call(fetch, '/todos');

select
用于从 state 里获取数据。

const todos = yield select(state => state.todos);

错误处理
全局错误处理

dva 里,effects 和 subscriptions 的抛错全部会走 onError hook,所以可以在 onError 里统一处理错误。

const app = dva({onError(e, dispatch) {console.log(e.message);},
});

然后 effects 里的抛错和 reject 的 promise 就都会被捕获到了。

本地错误处理
如果需要对某些 effects 的错误进行特殊处理,需要在 effect 内部加 try catch 。

app.model({effects: {*addRemote() {try {// Your Code Here} catch(e) {console.log(e.message);}},},
});

异步请求

GET 和 POST

import request from '../util/request';// GET
request('/api/todos');// POST
request('/api/todos', {method: 'POST',body: JSON.stringify({ a: 1 }),
});

统一错误处理
假如约定后台返回以下格式时,做统一的错误处理。

{status: 'error',message: '',
}

编辑 utils/request.js,加入以下中间件:

function parseErrorMessage({ data }) {const { status, message } = data;if (status === 'error') {throw new Error(message);}return { data };
}

然后,这类错误就会走到 onError hook 里。

Subscription
subscriptions 是订阅,用于订阅一个数据源,然后根据需要 dispatch 相应的 action。数据源可以是当前的时间、服务器的 websocket 连接、keyboard 输入、geolocation 变化、history 路由变化等等。格式为

({ dispatch, history }) => unsubscribe 。

异步数据初始化
比如:当用户进入 /users 页面时,触发 action users/fetch 加载用户数据。


app.model({subscriptions: {setup({ dispatch, history }) {history.listen(({ pathname }) => {if (pathname === '/users') {dispatch({type: 'users/fetch',});}});},},
});

path-to-regexp Package
如果 url 规则比较复杂,比如 /users/:userId/search,那么匹配和 userId 的获取都会比较麻烦。这是推荐用 path-to-regexp 简化这部分逻辑。

import pathToRegexp from 'path-to-regexp';// in subscription
const match = pathToRegexp('/users/:userId/search').exec(pathname);
if (match) {const userId = match[1];// dispatch action with userId
}

Router
Config with JSX Element (router.js)

<Route path="/" component={App}><Route path="accounts" component={Accounts}/><Route path="statements" component={Statements}/>
</Route>

详见:react-router

Route Components
Route Components 是指 ./src/routes/ 目录下的文件,他们是 ./src/router.js 里匹配的 Component。

通过 connect 绑定数据
比如:

import { connect } from 'dva';
function App() {}function mapStateToProps(state, ownProps) {return {users: state.users,};
}
export default connect(mapStateToProps)(App);

然后在 App 里就有了 dispatch 和 users 两个属性。

Injected Props (e.g. location)

Route Component 会有额外的 props 用以获取路由信息。

location
params
children

基于 action 进行页面跳转

import { routerRedux } from 'dva/router';// Inside Effects
yield put(routerRedux.push('/logout'));// Outside Effects
dispatch(routerRedux.push('/logout'));// With query
routerRedux.push({pathname: '/logout',query: {page: 2,},
});

除 push(location) 外还有更多方法,详见 react-router-redux

dva 配置

Redux Middleware
比如要添加 redux-logger 中间件:

import createLogger from 'redux-logger';
const app = dva({onAction: createLogger(),
});

注:onAction 支持数组,可同时传入多个中间件。

history
切换 history 为 browserHistory

import { browserHistory } from 'dva/router';
const app = dva({history: browserHistory,
});

去除 hashHistory 下的 _k 查询参数

import { useRouterHistory } from 'dva/router';
import { createHashHistory } from 'history';
const app = dva({history: useRouterHistory(createHashHistory)({ queryKey: false }),
});

工具
通过 dva-cli 创建项目
先安装 dva-cli 。

$ npm install dva-cli -g

然后创建项目。

$ dva new myapp

最后,进入目录并启动。

$ cd myapp
$ npm start

每天一句中文式外语

すみません(死咪妈森)对不起
ありがとございます(啊里旮兜狗达一妈死)谢谢
いいえ,どういたしまして(易爷,豆以他西妈西忒)不用谢
おやすみなさい(呕丫死咪那塞)晚安
はい(害易)是的
いいえ(易爷)不是的
いただきます(以它搭ki妈寺)我吃啦
ごちそうさまでした(狗期搜物撒妈得西它)我吃好了
はは(哈哈)妈妈
ちち(欺欺)爸爸
そふ(搜咐)祖父/外祖父
そば(搜吧)祖母/外祖母
りょうしん(料心)父母
むすこ(姆思抠)儿子
むすめ(姆思没)女儿
あに(啊妮)哥哥
あね(啊内)姐姐
おとうと(哦偷务透)弟弟
いもうと(以摸乌透)妹妹
おじ(哦激)伯伯/叔叔/舅舅/姑父
查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. Python数字图像处理---1.1图像的像素格式与图像读写

    目录 前言 图像像素格式 图像读写 前言 本专栏面向所有希望或有兴趣从事数字图像处理工作、学习或研究的朋友,编程语言采用了当下最火的Python语言。 Python是一种跨平台的计算机设计语言,也是一个高层次的结合了解释性、编译性、互动性和面向对象的脚本语言,被方便的应用…...

    2024/5/1 17:57:23
  2. Vue ElementUI 上传图片文件 全栈 从前端到后端实战

    本文目录&#xff1a; 1.前端form表单 2.api/owner.js中制定接口 3.后端处理 4.前端处理返回的数据1.前端form表单如下&#xff1a; :action是表示图片提交的地址&#xff0c;action后面必须为地址或提交到后台的路径&#xff0c;不能为方法。 :on-success"handleUploadS…...

    2024/4/23 21:54:09
  3. arduino配置esp32-cam开发环境使用摄像头

    1&#xff09;从Arduino IDE转到文件 > 首选项 2&#xff09;在“其他Board Manager URL”字段中输入 https://dl.espressif.com/dl/package_esp32_index.json&#xff0c;如下图所示。然后&#xff0c;单击“好”按钮&#xff1a; 3&#xff09;工具->开发板->开发…...

    2024/5/1 1:36:05
  4. (2020.09.29)mysql报错 Table ‘mysql.host‘ doesn‘t exist

    昨天重新安装完MySQL后运行了一下 今天再次打开sqlyog连接数据库却怎么也连不上 后来查了很多资料学会在.err文件里面查看日志 结果发现Table mysql.host’ doesn’t exist错误 后面发现是安装路径data文件夹中没有mysql文件 解决办法 从安装文件MySQL\app\data中复制mysql…...

    2024/4/23 17:15:33
  5. jQuery今日总结

    jQuery 教程 jQuery 是一个 JavaScript 库。 jQuery 极大地简化了 JavaScript 编程。 jQuery 很容易学习。 本章节的每一篇都包含了在线实例 通过本站的在线编辑器&#xff0c;你可以在线运行修改后的代码&#xff0c;并查看运行结果。 实例 $(document).ready(function()…...

    2024/5/1 17:56:56
  6. 学习的第六天

    六、BUUCTF-WEB-[HCTF 2018]WarmUp 我们打开网址&#xff0c;看到了一个大大的“滑稽”。 很明显这并不能给我们有用的信息&#xff0c;所习惯性F12&#xff0c;看看源代码里会有什么收获。 发现了一段注释&#xff0c;似乎是一个文件&#xff0c;尝试进入。 发现是一段代码…...

    2024/4/23 12:28:52
  7. java学习日记02---jdk环境变量的意义

    配置jdk时&#xff0c;需要两个环境变量 path&#xff1a;告诉操作系统执行命令时到哪个目录里寻找。例如java,javac都是要执行的命令。但是如果不在bin/目录下执行&#xff0c;操作系统找不到java,javac在哪&#xff0c;需要把其所在目录/bin配置到path中&#xff0c;这样无论…...

    2024/5/3 2:32:50
  8. 九月学习总结(7)

    1.指出数组中和最大的子序列&#xff08;子序列需要保持连续性&#xff09;并显示初始和结束位置 import java.util.Scanner; //第一种暴力求解法 public class Zuidazixulie {public static void main(String[] args) {Scanner strnew Scanner(System.in);String resstr.next…...

    2024/4/23 20:04:12
  9. Go语言之goroutine详解

    有很多人对 goroutine还不死很理解&#xff0c;goroutine 是 Go语言中的轻量级线程实现&#xff0c;由 Go 运行时&#xff08;runtime&#xff09;管理。Go 程序会智能地将 goroutine 中的任务合理地分配给每个 CPU。 goroutine由来 在编写 Socket 网络程序时&#xff0c;需要…...

    2024/4/23 12:21:56
  10. C++ STL algobase.h

    全部代码 #pragma once#include <cstring>#include "util.h" #include "iterator.h"namespace tinySTL {template<typename T>const T& max(const T& lhs, const T& rhs) {return lhs < rhs ? rhs : lhs;}template<typena…...

    2024/5/2 16:08:33
  11. 大数据——Elasticsearch(存储+检索+分析)

    ElasticsearchELK StackElasticsearch简介Elasticsearch安装和配置Elasticsearch数据模型文档&#xff08;Document&#xff09;管理&#xff08;一&#xff09;文档&#xff08;Document&#xff09;管理&#xff08;二&#xff09;文档&#xff08;Document&#xff09;管理&…...

    2024/5/3 7:26:46
  12. 怎么同时编辑多处/怎么多光标

    IntelliJ IDEA怎么同时编辑多处 怎么多光标...

    2024/5/2 20:40:08
  13. LeetCode 1232. 缀点成线

    目录结构 1.题目 2.题解 1.题目 在一个 XY 坐标系中有一些点&#xff0c;我们用数组 coordinates 来分别记录它们的坐标&#xff0c;其中 coordinates[i] [x, y] 表示横坐标为 x、纵坐标为 y 的点。 请你来判断&#xff0c;这些点是否在该坐标系中属于同一条直线上&#x…...

    2024/5/2 20:39:51
  14. 工作10年程序员总结的10个血泪教训!

    1. 不要轻易换笔记本电脑&#xff0c;不要跟潮流&#xff0c;不要买过多的电子产品&#xff0c;不要过于频繁的更换手机。 这方面我的经验教训也是惨痛的。我大概前后购买过 5-6 个笔记本&#xff0c;以前的都是 1 万多元一台&#xff0c;最近买的这台 1 万多是给女朋友的&…...

    2024/5/2 5:37:02
  15. 模拟信号和数字信号

    模拟信号是一种信号与信息的不断变化的物理量表示。例如&#xff0c;一个无线电信号。模拟信号是连续的。模拟通信的优点是直观&#xff0c;易于实现。但它有两个主要的缺点。 首先是&#xff0c;模拟通信&#xff0c;尤其是微波通信和有线通信&#xff0c;很容易被窃听。 其次…...

    2024/5/1 8:27:38
  16. day7

    day7 集合 集合是容器型数据类型&#xff0c;将{}作为容器的标志&#xff0c;里面多个元素用逗号隔开&#xff1a;{元素1&#xff0c;元素2&#xff0c;元素3.。。。} #空集合 x {} #空字典 s1 set() #空集合 print(type(x),type(s1)) #<class dict> <class set&…...

    2024/4/27 1:43:36
  17. 优雅的使用线程池

    线程池不仅在项目中是非常常用的一项技术而且在面试中基本上也是必问的知识点&#xff0c;接下来跟着我一起来巩固一下线程池的相关知识。在了解线程池之前我们先了解一下什么是进程什么是线程 进程 程序&#xff1a;一般是一组CPU指令的集合构成的文件&#xff0c;静态存储在…...

    2024/5/3 14:33:19
  18. css学习2

    1.不常见伪类选择器 :default 指向单选多选框中checked的元素&#xff08;相当于默认选中&#xff09;:empty 指标签内无任何字符串的元素:placeholer-shown input提示内容出现时的元素&#xff0c;可以用于修改label选中时的位置&#xff08;所以为什么不用focus呢&#xff1…...

    2024/5/1 6:06:28
  19. # 2020-09-29 #「计算机网络」- 使用iperf测试网络吞吐

    内容简介 本文将介绍如何使用iperf进行网络吞吐测试。 iperf ? 通过iperf工具&#xff0c;可以测试两台主机间网络吞吐&#xff0c;比如带宽、延迟、抖动、丢包等等。它可以测试TCP吞吐&#xff0c;也可以测试UDP吞吐。 工作原理 测试两台主机间的吞吐&#xff0c;需要在两台主…...

    2024/4/26 23:45:04
  20. Python——迭代器

    迭代器 迭代是Python最强大的功能之一&#xff0c;是访问集合元素的一种方式。 迭代器是一个可以记住遍历的位置的对象。 迭代器对象从集合的第一个元素开始访问&#xff0c;直到所有的元素被访问完结束。迭代器只能往前不会后退。 迭代器有两个基本的方法&#xff1a;iter() …...

    2024/4/25 12:36:42

最新文章

  1. 【UnityRPG游戏制作】NPC交互逻辑、动玩法

    &#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 秩沅 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a;就业…...

    2024/5/3 23:39:58
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. 蓝桥杯第十五届抱佛脚(十)贪心算法

    蓝桥杯第十五届抱佛脚&#xff08;十&#xff09;贪心算法 贪心算法基本概念 贪心算法是一种在算法设计中常用的方法&#xff0c;它在每一步选择中都采取在当前状态下最好或最优&#xff08;即最有利&#xff09;的选择&#xff0c;从而希望导致结果是最好或最优的算法。 贪…...

    2024/5/2 2:39:45
  4. 分享一个基于Multi-SLAM+3DGS的新一代三维内容生产技术

    基于智能空间计算&#xff0c;新一代超逼真三维内容生成技术。 可自动化生成超逼真的大场景三维模型&#xff0c;并在各类终端和空间计算设备中&#xff0c;实现前所未有的沉浸式体验。 更可接入专业三维软件和应用平台&#xff0c;进行深度的模型开发与场景落地。 支持超大复杂…...

    2024/5/3 1:31:22
  5. 416. 分割等和子集问题(动态规划)

    题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义&#xff1a;dp[i][j]表示当背包容量为j&#xff0c;用前i个物品是否正好可以将背包填满&#xff…...

    2024/5/3 11:50:27
  6. 【Java】ExcelWriter自适应宽度工具类(支持中文)

    工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...

    2024/5/2 16:04:58
  7. Spring cloud负载均衡@LoadBalanced LoadBalancerClient

    LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon&#xff0c;直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件&#xff0c;我们讨论Spring负载均衡以Spring Cloud2020之后版本为主&#xff0c;学习Spring Cloud LoadBalance&#xff0c;暂不讨论Ribbon…...

    2024/5/2 23:55:17
  8. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

    一、背景需求分析 在工业产业园、化工园或生产制造园区中&#xff0c;周界防范意义重大&#xff0c;对园区的安全起到重要的作用。常规的安防方式是采用人员巡查&#xff0c;人力投入成本大而且效率低。周界一旦被破坏或入侵&#xff0c;会影响园区人员和资产安全&#xff0c;…...

    2024/5/3 16:00:51
  9. VB.net WebBrowser网页元素抓取分析方法

    在用WebBrowser编程实现网页操作自动化时&#xff0c;常要分析网页Html&#xff0c;例如网页在加载数据时&#xff0c;常会显示“系统处理中&#xff0c;请稍候..”&#xff0c;我们需要在数据加载完成后才能继续下一步操作&#xff0c;如何抓取这个信息的网页html元素变化&…...

    2024/5/3 11:10:49
  10. 【Objective-C】Objective-C汇总

    方法定义 参考&#xff1a;https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...

    2024/5/3 21:22:01
  11. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

    &#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】&#x1f30f;题目描述&#x1f30f;输入格…...

    2024/5/3 23:17:01
  12. 【ES6.0】- 扩展运算符(...)

    【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数&#xff0…...

    2024/5/2 23:47:43
  13. 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?

    文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕&#xff0c;各大品牌纷纷晒出优异的成绩单&#xff0c;摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称&#xff0c;在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁&#xff0c;多个平台数据都表现出极度异常…...

    2024/5/3 13:26:06
  14. Go语言常用命令详解(二)

    文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令&#xff0c;这些命令可以帮助您在Go开发中进行编译、测试、运行和…...

    2024/5/3 1:55:15
  15. 用欧拉路径判断图同构推出reverse合法性:1116T4

    http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b&#xff0c;我们在 a i a_i ai​ 和 a i 1 a_{i1} ai1​ 之间连边&#xff0c; b b b 同理&#xff0c;则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然&#xff0…...

    2024/5/2 9:47:28
  16. 【NGINX--1】基础知识

    1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息&#xff0c;并安装一些有助于配置官方 NGINX 软件包仓库的软件包&#xff1a; apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...

    2024/5/3 16:23:03
  17. Hive默认分割符、存储格式与数据压缩

    目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限&#xff08;ROW FORMAT&#xff09;配置标准HQL为&#xff1a; ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...

    2024/5/3 1:55:09
  18. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

    文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中&#xff0c;传感器和控制器产生大量周…...

    2024/5/2 8:37:00
  19. --max-old-space-size=8192报错

    vue项目运行时&#xff0c;如果经常运行慢&#xff0c;崩溃停止服务&#xff0c;报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中&#xff0c;通过JavaScript使用内存时只能使用部分内存&#xff08;64位系统&…...

    2024/5/3 14:57:24
  20. 基于深度学习的恶意软件检测

    恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞&#xff0c;例如可以被劫持的合法软件&#xff08;例如浏览器或 Web 应用程序插件&#xff09;中的错误。 恶意软件渗透可能会造成灾难性的后果&#xff0c;包括数据被盗、勒索或网…...

    2024/5/2 9:47:25
  21. JS原型对象prototype

    让我简单的为大家介绍一下原型对象prototype吧&#xff01; 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定&#xff0c;每一个构造函数都有一个 prototype 属性&#xff0c;指向另一个对象&#xff0c;所以我们也称为原型对象…...

    2024/5/2 23:47:16
  22. C++中只能有一个实例的单例类

    C中只能有一个实例的单例类 前面讨论的 President 类很不错&#xff0c;但存在一个缺陷&#xff1a;无法禁止通过实例化多个对象来创建多名总统&#xff1a; President One, Two, Three; 由于复制构造函数是私有的&#xff0c;其中每个对象都是不可复制的&#xff0c;但您的目…...

    2024/5/3 22:03:11
  23. python django 小程序图书借阅源码

    开发工具&#xff1a; PyCharm&#xff0c;mysql5.7&#xff0c;微信开发者工具 技术说明&#xff1a; python django html 小程序 功能介绍&#xff1a; 用户端&#xff1a; 登录注册&#xff08;含授权登录&#xff09; 首页显示搜索图书&#xff0c;轮播图&#xff0…...

    2024/5/3 7:43:42
  24. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

    C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...

    2024/5/3 1:54:59
  25. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  26. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  28. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  29. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  30. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  31. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  32. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  35. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  36. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  37. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  38. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  39. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  40. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  41. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  42. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  43. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  44. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57