Angular vs React

Angular vs. React是前端JavaScript开发人员中的热门争论,而且,讨论最终往往偏向于一种技术或另一种技术。 分别由Google和Facebook开发的Angular和React是用于构建交互式单页应用程序的两种流行技术。

迫切需要对Angular和React进行全面的比较,因为在某些地方它们在它们提供的内容上有很大的重叠,即,构建应用程序的前端视图以及其他地方,除非获得第三方的帮助,否则它们的功能仍然不完整。政党图书馆。 采用一种技术而不是另一种技术是一个问题,即Angular或React是否可以更好地解决您的问题和一些直觉。 在本教程中,我们将比较和对比Angular和React的七个关键不同功能。

我是代码优先方法的热心拥护者(他们说,代码胜于雄辩)。 牢记这一点,我尽可能地添加了Angular和React的代码示例,以便您可以凭直觉确定哪个对您有用,哪些不起作用。 让我们开始吧。

框架与库

Angular是一个框架,而React是一个库。

那么这是什么意思? React本身不允许您创建Web应用程序,因为它旨在创建视图(因此在MVC中为“ V”)。 React可以做的是构建基于组件的视图,可以将这些数据向下传递到子视图。 为了填补这一空白,Facebook开发了Flux ,这是一种补充React的架构模式。 当Flux架构与React结合使用时,可提供以下场景:

  1. 用户单击React元素。
  2. 动作被触发。 此操作通过分派器库分派到商店。
  3. 该商店跟踪应用程序的状态和数据检索方法。 状态的任何更新都会反映在视图中,这有助于使视图与应用程序的状态保持一致。

没道理吗 这个数字应该可以为您解决。

该图描绘了Flux架构如何补充React
Flux是React的补充,并实现了单向数据流的概念。

Angular是用于构建客户端应用程序的框架。

AngularJS牢固地构建在MVC模式的顶部,该模式将应用程序分为三个不同的层。 模型,视图和控制器的结合,以及在掌握指令,工厂,服务和其他组件以创建单页应用程序时所涉及的复杂性的增加,迫使Google的开发人员转向基于组件的体系结构。

但是,当您的应用程序开始增长时,拥有一个牢固的结构以使应用程序的业务逻辑远离组件很重要。 作为框架,Angular允许您通过将业务规则移至域模型(使用模型类和服务的组合)并通过依赖注入将模型注入到组件中来实施结构化组织。

下面的代码示例说明了如何将业务逻辑封装在用户模型和用户服务内,以及如何远离我们的组件。

/* Path: /app/models/User.ts */export class User {id: number;username: string;password: string;firstName: string;lastName: string;
}
/* /app/services/user.service.ts */import { Injectable } from '@angular/core';
import { Http } from '@angular/http';import { User } from '../models/User';@Injectable()
export class UserService {constructor(private https: Http) { }getAll() {// API to return all users}create(user: User) {//API call to create user}update(user: User) {//API call to update user}delete(id: number) {//API call to delete user}}
/* Path: /app/page/page.component.ts */import { Component } from '@angular/core';import { User } from '../models/User';
import { UserService } from '../services/user.service';@Component({templateUrl: 'page.component.html'
})export class PageComponent {currentUser: User;users: User[] = [];constructor(private userService: UserService) {//Dependency is Injected inside the constructor's argumentsdeleteUser(id: number) {this.userService.delete(id).subscribe(() => { #Do Something});}private loadAllUsers() {this.userService.getAll().subscribe(users => { #Do something else });}
}
<!---Path: /app/home/page.component.html --><div class="title"><h2>All users:</h2><ul><li *ngFor="let user of users">{{user.username}} ({{user.firstName}} {{user.lastName}})- <a (click)="deleteUser(user.id)">Delete</a></li></ul></div>

基于组件的方法

组件是Angular应用程序中UI的最基本构建块。 Angular应用程序是Angular组件树。

什么是成分? 在Angular中,组件是TypeScript类,在其上标记了@Component装饰器。 此外,在这些装饰器中,我们可以定义Angular所谓的元数据,其中包括模板,样式,选择器等。

Angular中的组件层次结构设计为可以在单个实体下关联结构和功能。 这是组件的高层架构概述,以及如何将其链接到Angular中的其他所有组件。

Angular的体系结构
Angular的体系结构。 组件位于中心,其他所有内容都围绕它旋转。

组件之间的数据共享可以通过嵌套组件来实现,如下所示。

/* UserParentComponent.ts */import { Component } from '@angular/core';// The <user-child> selector is nested inside <user-parent>. Each user is passed down as a property. @Component({selector: 'user-parent',template: `<h2>There are {{users.length}} registered users {{status}} now</h2><user-child *ngFor="let user of users"[user]="user"[status]="status"></user-child>`
})
export class UserParentComponent {users: { id: number, name: string }[] = [{ "id": 0, "name": "Chris" },{ "id": 1, "name": "Dwayne" },{ "id": 2, "name": "Eve" }];status: string =  "online";}
/* UserChildComponent.ts */import { Component, Input } from '@angular/core';// Input properties are adorned with @decorators
// user & status are input properties@Component({selector: 'user-child',template: `<h2>{{user.name}}</h3><p> id : {{user.id}} </p><p> Status: {{status}} </p>`
})
export class UserChildComponent {@Input() user: { id: number, name: string };@Input() status: string;
}

组件的概念与Angular一样,深深植根于React。 Facebook称React为一个基于组件的库,可让您构建交互式用户界面。 但是,与Angular不同,React组件只是具有任意数量的input和output的 JavaScript函数。 下面的代码显示了使用JavaScript函数和ES6类定义的组件。

// Writing components using JavaScript functionsfunction Welcome(props) {return <h1>Hello, {props.name}</h1>;
}// Writing components using ES6 Classclass Welcome extends React.Component {render() {return <h1>Hello, {this.props.name}</h1>;}
}

今后,我们将遵循ES6标准来组成组件,因为这是Facebook的建议。 每个React组件接受任意数量的输入,这些输入存储在名为props的对象中。

它还有一个render方法,顾名思义,此方法确定调用组件时将呈现的内容。 每个组件都维护一个内部状态(通过this.state ),并且每次状态更改时,都会再次调用该组件的render函数。

语言功能:TypeScript与ES6

Angular应用程序是用TypeScript编写的,它是ECMA2015的超集,并使用编译器将强类型的.ts文件编译为纯.js文件。 TypeScript提供了旨在使使用JavaScript编写变得更容易的语言扩展,并且将类型信息与JavaScript实体相关联以强制进行类型检查并增强开发工作流程。

TypeScript的一些关键功能包括可选的静态类型以及对接口,类和装饰器的支持。 (装饰器是以“ @”为前缀的函数,紧随其后的是类,参数或属性。)

让我们深入研究React,好吗? 在此代码示例中,React的重要语言功能之一显而易见。

function Tweet(props) {return(<div className="tweet"><img src="http://twitter.com/some-avatar.png" className="tweet__avatar" /><div className="tweet__body"><p>This is a tweet.</p>  </div></div>);
}

这不是很好吗? React使您可以将XML / HTML标记嵌入到JavaScript文件中,而这是通过JSX完成的,它提供了JavaScript的语法扩展功能。 我们必须使用Babel这样的编译器,它将我们的JSX代码编译为浏览器可以理解JavaScript。 上面的代码编译为:

"use strict";function Tweet(props) {return React.createElement("div",{ className: "tweet" },React.createElement("img", { src: "http://twitter.com/some-avatar.png", className: "tweet__avatar" }),React.createElement("div",{ className: "tweet__body" },React.createElement("p",null,"This is a tweet.")));
}

尽管建议使用JSX,但是如果您反对将HTML标签嵌入JavaScript的想法,则可以坚持使用React.createElement()

此外,在使用React时,您可以使用ES6标准或传统形式JavaScript。 尽管ES6相对较新,但它增加了许多功能,例如类,箭头函数,模板文字,析构以及let和const的使用。 我能想到的唯一缺点是,它增加了一些样板代码,例如每次调用constructor()都需要调用super() constructor() ,并且它不会自动与this绑定事件处理方法。

class User extends React.Component {constructor(props) {//bloat code alertsuper(props);this.handleSubmit = this.handleSubmit.bind(this);this.handleInputChange = this.handleInputChange.bind(this);}handleSubmit(user) {//Method to handle submit}handleInputChange(user) {//Method to handle input}render() {return (<div><UserRegistrationonSubmitSuccess={this.handleSubmit} onInputChange={this.handleInputChange}  /></div>);}
}

在React中的Angular和PropType中进行类型检查

静态类型检查在编译时执行。 编译器会警告您有关潜在的类型不匹配的信息,并检测某些本来不会引起注意的错误。 此外,在变量,属性或函数的参数上定义契约可以使代码更具可读性和可维护性。

通过声明变量和函数的数据类型,可以使其更具表达性。 您可以在TypeScript文档中了解有关不同原始数据类型的更多信息。

let isLoggedIn: boolean = false;
let id: number = 10;
let name: string = "Davis";
let list: number[] = [1, 2, 3];enum Color {Red, Green, Blue};
let c: Color = Color.Red;
let bucket: any = 4;
bucket = "I can be a string";
bucket = false; // or a boolean

使用接口定义API的签名,可以减少代码的歧义并使其易于理解。 该界面可作为快速入门指南,帮助您立即开始使用代码,并节省在阅读文档或库的实际实现上所花费的时间。

interface ButtonSettings {text: string;size?: { width: number; height: number; };color?: string;
}function createButton(settings: ButtonSettings) { ... }createButton({ text: 'Submit' }); // OK
createButton({ text: 'Submit', size: { width: 70, height: 30 }}); // OK
createButton({ text: 'Submit', color: 43); // Not OK: 43 isn't a string
createButton({ text: 'Submit', size: { width: 70 }); // Not OK: size needs a height as well
createButton({ color: 'Blue'}); // Not OK: 'text' member is required

TypeScript中的type关键字可用于为类型创建别名。 然后,您可以创建新类型,这些新类型是这些原始类型的并集或交集。

//Union Typestype Age = number | string;
function getAge (age: Age): string {return `You are ${age}!`;
}let ofSusan: Age =21;
let ofTyler: Age = 'thirty one';
getAge(ofSusan); // You are 21!
getAge(ofTyler); // You are thirty one!//Intersection Typesinterface Name{name(firstName: string, lastName: string): string;
}interface Age {age(current: number): number;
}
// assign intersection definition to alias User
type User = Name & Age;function createUser (testUser: User) {testUser.name("David","John");testUser.age(99);testUser.address(); //error

由于底层的ES6不支持,所以React对类型检查的支持有限。 不过,您可以使用React团队开发的prop-types库实现类型检查。 可以如下所示对组件的props进行类型检查,以检查它是否为字符串。

import PropTypes from 'prop-types';
//importing prop-types libraryclass Greeting extends React.Component {render() {return (<h1>Hello, {this.props.name}</h1><P> My age is, {this.props.age} </h2>);}
}Greeting.propTypes = {name: PropTypes.string;age: PropTypes.number;
};

但是prop-types不仅限于字符串,数字和布尔值。 如prop-types库文档中所述,您可以做更多的事情。 但是,如果您认真对待静态类型检查,则应使用Flow之类的东西,它是JavaScript的静态类型检查器库。

脚手架:Angular CLI与create-react-app

从头开始一个项目可能看起来很有趣。 但是,设置目录结构,编写组件的样板代码以及引导应用程序启动的过程是徒劳的,没有效率。 您的策略应该是尽快着手进行,并专注于应用程序的实际开发。 感谢Google和Facebook,您可以使用一些工具轻松地创建和构建应用程序。

使用npm可以轻松地为React设置angular-CLI和create-react-app。

// Angular CLI$ npm install -g @angular/cli// create-react-app$ npm install -g create-react-app

要创建新的Angular应用程序,应使用以下命令:

$ ng new PROJECT-NAME
$ ng serve

但这不是。 ng generate命令使您可以生成组件,路由,管道,指令和服务。

$ ng generate component Pageinstalling componentcreate src\app\page\page.component.csscreate src\app\page\page.component.htmlcreate src\app\page\page.component.spec.tscreate src\app\page\page.component.tsupdate src\app\app.module.ts

Angular CLI可以做很多事情,例如创建Angular应用程序的内部版本,用于运行单元测试的命令以及端到端测试。 您可以在GitHub上阅读有关它的更多信息。

另一方面, create-react-app是创建没有任何配置文件的React应用程序的正式支持方式。

$ npm install -g create-react-app

这应该创建一个功能完备的React应用程序,并照顾好所有Babel和webpack依赖项。 您可以使用npm start在浏览器上开始运行该应用npm start

您可以在package.json文件中找到可用于react应用程序的脚本。

"scripts": {"start": "react-scripts start","build": "react-scripts build","test": "react-scripts test --env=jsdom","eject": "react-scripts eject"}
}

数据绑定:双向绑定与单向绑定

数据绑定是一项使应用程序状态(模型)与视图之间的数据同步的功能。 在单向数据绑定例程中,应用程序状态的任何更改都会自动更新视图。 相反,双向数据绑定将单个实体下的属性和事件绑定在一起,即模型的任何修改都会更新视图,反之亦然。

在React中,属性从父组件传递到子组件,这被称为单向或自顶向下的数据流。 组件的状态已封装,其他组件无法访问,除非将其状态向下传递给子组件作为道具,即组件的状态成为子组件的道具。

class UserChild extends React.Component {render() {let userData = this.props.users.map( (user) => {return (<p> <strong>{user.id} </strong> : {user.name} </p>);});return (<div><h2> Hello. The server is {this.props.status} </h2>{userData}</div>);}
}class UserParent extends React.Component {constructor() {super();//State gets defined herethis.state = {status: "Online"}}render() {return (<div><UserChild users={this.props.users} status={this.state.status} /></div>);}
}var USERS = [{ "id": 0, "name": "Chris" },{ "id": 1, "name": "Dwayne" },{ "id": 2, "name": "Eve" }
];ReactDOM.render(<UserParent users={USERS} />,document.getElementById('container')
);

但是,如果您需要通过组件树向上传播数据怎么办? 这是通过子事件和父回调完成的。 React文档包含一个很好的例子来处理这种情况。

Angular中可用的数据绑定技术是使它有趣的一些功能之一。 Angular对插值,单向绑定,双向绑定和事件绑定提供了开箱即用的支持。

插值是将组件属性绑定到HTML标记和属性分配之间的文本内的最简单方法。

<p>Welcome back {{currentUser.name}}!</p>

在可以将视图元素的属性绑定到组件属性的意义上,属性绑定与插值相似。 属性绑定有利于组件通信,并且与在React中传递props相同。

<img [src]="userImgUrl">

<user-child [user]="currentUser"></user-child>

事件绑定允许数据沿相反的方向流动,即从元素到组件。 在这里, click是目标事件,在右侧,我们具有onSave()方法,该方法在事件发生时被调用。

<button (click)="onSave()">Save</button>

但是最重​​要的功能是使用[(ngModel)]的双向绑定。 这将属性绑定和事件绑定合并在一个指令下,对于表单和输入字段特别有用。

<div><label>name: </label><input [(ngModel)]="hero.name" placeholder="name">
</div>

服务器端渲染

服务器端渲染是一种传统的渲染技术。 在这里,服务器根据请求返回整个HTML文件,浏览器只剩下向用户显示文件的简单工作。 另一方面,客户端渲染将返回准HTML文档,样式表和JavaScript文件。

JavaScript发出随后的请求,以使用浏览器呈现网站的其余部分。 React,Angular和所有其他现代JavaScript前端库都是客户端渲染的很好示例。 如果查看Angular / React应用程序的源代码,这是显而易见的。

但是客户端渲染的缺点是,它不适用于SEO,并且当您在社交媒体网站上共享链接时,它会返回不完整HTML内容。 Angular提供了一个名为Angular Universal的解决方案,该解决方案可以使您的应用搜索引擎友好且对社交媒体友好。 这是由Angular团队构建的库,使用它肯定是受青睐的。

Universal利用预渲染技术,首先从服务器渲染整个网站,然后在几秒钟后,将用户切换到客户端渲染。 由于所有这些都是在后台进行的,因此用户不会注意到任何不同。

如果您将React与Redux一起使用,则Redux文档提供了有关设置服务器渲染的很好的教程。 您还可以使用react-router库中提供的BrowserRouterStaticRouter组件将React设置为从服务器进行渲染。 您可以在这篇中型文章中阅读有关它的更多信息。 但是,如果您想进行性能和优化,则可以尝试next.js ,这是React中用于SSR的库。

包起来

将成熟的,功能丰富的框架与健壮的UI库进行比较似乎并不公平。 但是,它们是用于创建交互式单页应用程序的高级JavaScript技术,在这一方面,本文应帮助您决定选择其中一种。

您对Angular与React有何看法? 请在下面的评论中分享它们。

翻译自: https://code.tutsplus.com/articles/angular-vs-react-7-key-features-compared--cms-29044

查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. Angular4以上解决跨域问题

    1.利用nodeexpress搭建后台&#xff1a; import * as express from expressconst app express();export class Product {constructor(public id: number,public title: string,public price: number,public rating: number,public desc: string,public categories: Array<…...

    2024/4/22 23:14:33
  2. 细说 Angular 的自定义表单控件

    我们在构建企业级应用时&#xff0c;通常会遇到各种各样的定制化功能&#xff0c;因为每个企业都有自己独特的流程、思维方式和行为习惯。有很多时候&#xff0c;软件企业是不太理解这种情况&#xff0c;习惯性的会给出一个诊断&#xff0c;『你这么做不对&#xff0c;按逻辑应…...

    2024/4/21 2:23:17
  3. 2020年十本最值得阅读的前端书籍推荐(本文送书10本)

    送书规则留言点赞最多&#xff0c;共 5 名 在本文中留言&#xff0c;其中留言被点赞最多的前 5 名可以获得前端书籍一本&#xff0c;在本文推荐的10本书中自行选择点在看&#xff0c;随机选 5 名 在本文点在看&#xff0c;我这里是能看到谁点了再看的&#xff0c;随机抽 5 名可…...

    2024/4/21 2:23:16
  4. Angular4学习笔记(三)- 路由

    路由简介 路由是 Angular 应用程序的核心&#xff0c;它加载与所请求路由相关联的组件&#xff0c;以及获取特定路由的相关数据。这允许我们通过控制不同的路由&#xff0c;获取不同的数据&#xff0c;从而渲染不同的页面。 相关的类 Routes Routes其实是一个Route类的数组。…...

    2024/4/21 2:23:15
  5. Angular Service入门

    1.Angular内置service Angular为了方便开发者开发&#xff0c;本身提供了非常多的内置服务。可以通过https://docs.angularjs.org/api/ng/service查看AngularJS提供的内置服务。在企业级开发中&#xff0c;常用的服务有以下这些&#xff1a; $cacheFactory 缓存服务 $compile …...

    2024/4/21 2:23:14
  6. Angular2-使用Angular CLI快速搭建工程

    写文章注册登录首页下载AppAngular2-使用Angular CLI快速搭建工程&#xff08;一&#xff09;yitalalww 关注2016.12.02 14:39* 字数 2475 阅读 47025评论 78喜欢 106赞赏 6前言&#xff1a;本文适合Angular2的初学者阅读&#xff1b;时下web前端发展迅猛&#xff0c;新框架层出…...

    2024/4/21 2:23:13
  7. Angular之旅:启程

    angular的架构&#xff1a; Angular的中文网站上对于A有过一段这样的话&#xff1a;“ 我们是这样写 Angular 应用的&#xff1a;用 Angular 扩展语法编写 HTML 模板&#xff0c;用组件类管理这些模板&#xff0c;用服务添加应用逻辑&#xff0c;用模块打包发布组件与服务。 ”…...

    2024/4/21 23:46:38
  8. Angular2学习资源汇总

    Angular2学习资源 视频:https://my.oschina.net/mumu/blog/834254 资源&#xff1a;https://my.oschina.net/mumu/blog/831790文档博客书籍类 Angular University&#xff1a; http://blog.angular-university.io/ Jason Watmores Blog&#xff1a; http://jasonwatmore.com…...

    2024/4/21 2:23:11
  9. angular快速入门指南

    最近项目里用的AngularJs&#xff0c;把angular再复习一遍简介AngularJS是一个前端JavaScript框架&#xff0c;背后有Google支持。这个框架最早是09年发布的&#xff0c;随后发展迅速&#xff0c;尤其是最近&#xff0c;流行度很高。和其他框架不同&#xff0c;AngularJS有很多…...

    2024/4/26 19:36:19
  10. angular2概述

    强烈推荐一个大神的人工智能的教程&#xff1a;http://www.captainbed.net/zhanghan 简介 我主要从事后端开发&#xff0c;最近有幸参加了一个前端的项目&#xff0c;前后端分离&#xff0c;使用到的技术是angular2&#xff0c;因为之前工作有一些typescript的基础&#xff0c…...

    2024/4/21 2:23:09
  11. 【Angular2】生成条形码并打印网页

    引言 项目中要用到生成一系列的条形码&#xff0c;并在网页中打印 前端用的是Angular2&#xff0c;在实现的过程中查找了许多资料&#xff0c;以下是相关总结 步骤 1.下载JsBarcode.all.js 下载地址&#xff1a;http://download.csdn.net/download/francis123580/10130270 …...

    2024/4/21 2:23:08
  12. Angular2入门(一)

    原先用vue.js写的项目&#xff0c;最近领导要求改用Angular&#xff0c;于是开始自学之路。网上搜索了众多资料&#xff0c;包括谷歌原版书籍&#xff0c;但是Angular自从17年开始分为AngularJs和Angular两个版本&#xff0c;相差巨大&#xff0c;并且Angular已从2.0更新到6.0&…...

    2024/4/21 2:23:08
  13. Angular与服务器通讯

    创建Web服务器 使用Nodejs创建服务器 使用typescript语言开发服务器 配置开发环境 1. –> npm init -y 初始化文件夹&#xff0c;-y&#xff1a;建立包含默认配置的package.json文件 2. –> npm i types/node --save 引入node的类型定义文件 类型定义文件:让开发者在ty…...

    2024/4/21 2:23:06
  14. 在Angular 8中使用自定义MultiSelect下拉菜单创建动态行

    目录 介绍 如何工作&#xff1f; 先决条件 使用代码 第1步 第2步 第3步 第4步 第5步 第6步 第7步 第8步 第9步 第10步 第11步 结论 介绍 在本文中&#xff0c;我们将学习如何使用Angular 8创建动态行和自定义多选下拉列表。 用于Web应用程序的Angular multis…...

    2024/4/26 12:48:19
  15. angularJs service服务(例子主要用angular内置服务http服务)

    angularJs service服务 什么是服务&#xff1f; 服务是一个广义的概念&#xff0c;它包括应用所需的任何值、函数或特性。狭义的服务是一个明确定义了用途的类。它应该做一些具体的事&#xff0c;并做好。 Angular 把组件和服务区分开&#xff0c;以提高模块性和复用性。 通过…...

    2024/4/21 2:23:04
  16. Angular——在线竞拍demo

    因为是用angular开发“在线竞拍”主页面&#xff0c;所以就利用组件化的思想&#xff0c;先把主界面划分为7个组件&#xff0c;分别为&#xff1a;导航栏、搜索列表、产品信息、轮播图、脚注、星级评价&#xff0c;界面图片和每个组件的详细设计如下&#xff01; *导航栏 1.…...

    2024/4/21 2:23:03
  17. Angular vs AngularJS – Angular和AngularJS之间的区别

    In this article, you will learn about the difference between Angular and AngularJS. 在本文中&#xff0c;您将了解Angular和AngularJS之间的区别。 角度的 (Angular) It is a very well known top front-end framework. It uses Microsoft’s TypeScript language which…...

    2024/4/21 22:33:20
  18. 《Angular之图书馆后起之秀》

    前言&#xff1a; 随着ITOO开发的成熟&#xff0c;angular的深入研究&#xff0c;公司启动了图书馆软件开发项目。前端使用angular框架。小编担任此次的前端带领工作&#xff0c;培养后起之秀&#xff0c;预知细节如何&#xff0c;请听小编娓娓道来。 正文&#xff1a; 结语&a…...

    2024/4/26 17:55:46
  19. 【Angular】—— Angular学习详解思维导图 + 源码全部手打验证 [已完结]

    更新日志&#xff1a; [2019-09-24] 文章发布 说明&#xff1a; 本文是看Angular4的教程然后在Angular8上实现的&#xff0c;各种差异的补救&#xff0c;着实让我这个刚接触Angular的人来说很痛苦&#xff0c;不过都一 一克服了&#xff0c;所有代码均手敲验证过。由于思维导图…...

    2024/4/20 20:25:43
  20. Angular4 体积优化

    图书馆项目前端优化方案 使用命令&#xff1a;ng build –prod使用gulp进行图片&#xff0c;css&#xff0c;js压缩使用nginx开启gzip压缩Angular4升级到angular5进行压缩 1. 使用命令 1 npm install --save-dev angular/clilatest 2 npm install 3 ng build --prod --aot --…...

    2024/4/20 20:25:42

最新文章

  1. Java中的多线程编程与并发控制

    Java中的多线程编程与并发控制 一、引言 随着计算机硬件技术的不断发展&#xff0c;多核处理器已经成为现代计算机系统的标配。在这样的背景下&#xff0c;多线程编程与并发控制成为了Java开发中不可或缺的一部分。多线程编程能够充分利用多核处理器的并行计算能力&#xff0…...

    2024/4/26 20:13:50
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/3/20 10:50:27
  3. 【鸿蒙千帆起】《开心消消乐》完成鸿蒙原生应用开发,创新多端联动用户体验

    《开心消消乐》已经完成鸿蒙原生应用开发&#xff0c;乐元素成为率先完成鸿蒙原生应用开发的20游戏厂商之一。作为一款经典游戏&#xff0c;《开心消消乐》已经拥有8亿玩家&#xff0c;加入鸿蒙原生应用生态&#xff0c;将为其带来更优的游戏性能和更多创新体验。自9月25日华为…...

    2024/4/26 10:38:31
  4. 使用 PyOpenGL 进行 2D 图形渲染总结

    一、说明 OpenGL是一个广泛使用的开放式跨平台实时 3D 图形库&#xff0c;开发于二十多年前。它提供了一个低级API&#xff0c;允许开发人员以统一的方式访问图形硬件。在开发需要硬件加速且需要在不同平台上运行的复杂 2D 或 3D 应用程序时&#xff0c;它是首选平台。它可以在…...

    2024/4/26 17:26:20
  5. 记 SpringBoot 使用@RequestBody 接收不到参数

    POST请求&#xff0c;前端传的参数名字跟后端规定的参数一样。但是通过RequestBody注解接收的参数始终为NULL&#xff01; //实体类中属性没有用驼峰命名 private String SubscribeID; /*** 标题*/ private String Title;解决方案&#xff1a; 1、字段上使用JsonProperty(valu…...

    2024/4/25 20:36:30
  6. 【外汇早评】美通胀数据走低,美元调整

    原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...

    2024/4/26 18:09:39
  7. 【原油贵金属周评】原油多头拥挤,价格调整

    原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...

    2024/4/26 20:12:18
  8. 【外汇周评】靓丽非农不及疲软通胀影响

    原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...

    2024/4/25 18:38:39
  9. 【原油贵金属早评】库存继续增加,油价收跌

    原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...

    2024/4/25 18:39:23
  10. 【外汇早评】日本央行会议纪要不改日元强势

    原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...

    2024/4/25 18:39:22
  11. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

    原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...

    2024/4/25 18:39:22
  12. 【外汇早评】美欲与伊朗重谈协议

    原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...

    2024/4/25 18:39:20
  13. 【原油贵金属早评】波动率飙升,市场情绪动荡

    原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...

    2024/4/25 16:48:44
  14. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

    原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...

    2024/4/26 16:00:35
  15. 【原油贵金属早评】市场情绪继续恶化,黄金上破

    原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...

    2024/4/25 18:39:16
  16. 【外汇早评】美伊僵持,风险情绪继续升温

    原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...

    2024/4/25 18:39:16
  17. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

    原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...

    2024/4/26 19:03:37
  18. 氧生福地 玩美北湖(上)——为时光守候两千年

    原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...

    2024/4/25 4:19:21
  19. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

    原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...

    2024/4/25 18:39:14
  20. 氧生福地 玩美北湖(下)——奔跑吧骚年!

    原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...

    2024/4/25 18:39:12
  21. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

    原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...

    2024/4/25 2:10:52
  22. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

    原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...

    2024/4/25 18:39:00
  23. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

    原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...

    2024/4/26 19:46:12
  24. 广州械字号面膜生产厂家OEM/ODM4项须知!

    原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...

    2024/4/25 18:38:58
  25. 械字号医用眼膜缓解用眼过度到底有无作用?

    原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...

    2024/4/25 18:38:57
  26. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

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

    2022/11/19 21:17:18
  27. 错误使用 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
  28. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

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

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

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

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

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

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

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

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

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

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

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

    2022/11/19 21:17:10
  34. 电脑桌面一直是清理请关闭计算机,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
  35. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    2022/11/19 21:16:58
  45. 如何在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