原文地址:Angular’s $digest is reborn in the newer version of Angular

我已经从事Angular.js相关方面的工作好几年了,尽管这是一个饱受批评的框架,但我依旧认为它是极其出色的。一开始从《构建你自己的Angular.js》这本书入门,几年间我也阅读过框架的大部分源码,因此我坚信对于Angular.js内部的工作原理我有扎实的基础,也很好的领会了框架的思想。现在,对于新版Angular我试图达到与Angular.js相同的理解水平并对比版本间实现思想的差异。我发现,与网上声称的相反,Angular从前任借鉴的很多思想。

一个臭名昭著的思想是digest循环:

这会造成可怕的性能开销。应用中的任何改变都会导致成百上千的函数寻求变化。这是Angular(Angular.js)的基础组成部分,为了保持高性能,这将限制住构建应用时的UI数量。

尽管对angular(Angular.js)中的digest的实现有比较好的理解,但设计出高性能的应用依旧存在可能。比如说,选择性的使用$scope.$digest取代$scope.$apply以及拥抱不可变对象(译者注1)。事实上,理解框架内部实现才是构建高性能应用的必经之路,但这确实是大部分人的拦路虎。

这也难怪大部分教程都声称Angular摒弃了$digest循环。这个观点很大程度上取决于你对digest的定义,但我认为,鉴于其目的,这是一个误导性的说法。digest依旧存在,是的,我们不再明确的使用scopes和watchers,也不再调用$scope.$digest,但是遍历组件树、隐式调用watcher以及对DOM的更新,这些变化检测的机制给了Angular第二次生命。完全的重写,更强大的性能。

本文探讨了digest在Angular.js和Angular中实现的不同,无论对Angular的开发者还是那些想把项目从Anguar.js迁移到Angular上的人来说都是很有帮助的。

digest的必要性

在开始之前,让我们先回忆一下为什么digest会首先出现在angular.js中,很多框架都解决了数据模型(JavaScript对象)和UI(浏览器DOM)之间的同步问题,其中最大的挑战是对数据变化知悉的实现。我们把验证变化的过程叫做变化检测,它的实现是现今主流框架的最大区别,我计划写一篇关于变化检测在各个已存在框架中实现的对比,如果你对此感兴趣,请关注我。

有两种变化检测的方法 — 用户通知框架或者通过比较自动检测变化。假设我们有如下对象:

let person = {name: 'Angular'};

并且已经更新了name属性,那么框架是如何知道它已经被更新了呢?一种方法是要求用户去通知框架:

constructor() {let person = {name: 'Angular'};this.state = person;
}
...
//明确的对变化做出通知
this.setState({name: 'Changed'});

或者强迫对属性使用包装器,这样框架就可以对其添加setter:

let app = new Vue({data: {name: 'Hello Vue!'}
});
// 这个setter被触发,这样Vue就知道什么改变了
app.name = 'Changed';

另一种方法是将当前值与前值对比:

if (previousValue !== person.name) // 变化检测,更新DOM

每次运行代码都会伴随着验证的执行,那么什么时候应该完成比较呢?我们知道异步事件触发了上述代码的运行—称之为虚拟机轮询(VM turn/tick),我们可以在每次循环结束后开始校验,Angular.js中的digest也是这么做的,说到这里,我们可以给digest下个定义:

是一种变化检测的机制,通过遍历组件树,校验每个组件的的变化,并且在组件属性变化时更新DOM。

如果我们对digest如此定义,我敢断定在新版的Angular中这种主要机制没有改变,改变的仅仅是digest的具体实现。

Angular.js

Angular.js中使用了观察者(watcher)和监听器(listener)的概念。观察者函数会返回一个被观察的值,通常情况下这会是数据模型的属性,但这是不一定的-我们可以跟踪作用域上组件的状态、计算值、第三方组件等等。如果(watcher)返回的值与前值不同,那么angular就会调用监听器,监听器通常用于更新UI。

这些都反应在$watch这个函数参数中:

$watch(watcher, listener);

因此,如果我们在html(如:<span>{{name}}</span>)中使用了person对象的name属性,那么我们可以按照如下来代码追踪属性、更新DOM:

$watch(() => {return person.name
}, (value) => {span.textContent = value
});

这本质上就是angular.js中的插值表达式和指令(如:ng-bind)的实现。angular.js利用指令把数据映射到DOM中。新版Angular已经不这么做了, 它使用属性映射来连接数据模型和DOM。前面的例子现在是这样实现的:

<span [textContent]="person.name"></span>

因为我们有很多组件,每个组件拥有不一样的数据模型,因此我们拥有一个与组件树非常类似的watcher的层级结构。顺便说一下,watcher是使用$scope分组访问的。

Angular.js中digest 遍历watcher树并更新DOM,通常情况下,如果你使用现有的机制如$timeout,$http,$scope.$apply,$scope.$digest,那么每一次的异步事件会都会触发digest 循环。

观察者(watchers)按照严格的顺序触发—先是父级组件随后才是子组件。这有一定的道理,但某些情况下也会造成不好的影响。一个watcher的监听器(listener)存在各种各样的副作用,其中就包括更新父级组件的属性。如果父组件的监听器已经执行,但是子组件又更新了它的属性,那么这个变化将不被检测到。这就是为什么,digest 循环不得不运行多次才能稳定(确保没有更多变化)。循环次数被限制在10次。这个设计是有缺陷的,Angular已不再采用。

Angular

Angular 没有类似于Angular.js中的watcher的概念,但是模型属性的追踪还是存在的。这些更新的方法在框架编译时产生并且无法访问。它们也与底层的DOM有着强连接。这些方法被存在View的一个属性名叫updateRender的方法中。

这些方法是非常明确的,它们只追踪模型的变化而不是像Angular.js那样追踪所有。每一个组件有且仅有一个观察者(watcher),用于跟踪在模板中使用的所有组件属性。Angualr使用checkAndUpdateTextInline这个方法来追踪属性而不是返回一个值。这个方法对比当前值和前值而后更新DOM。

举个例子,AppComponent中存在如下模板:

<h1>Hello {{model.name}}</h1>

这将被编译成如下代码:

function View_AppComponent_0(l) {// jit_viewDef2 is `viewDef` constructorreturn jit_viewDef2(0,// array of nodes generated from the template// first node for `h1` element// second node is textNode for `Hello {{model.name}}`[jit_elementDef3(...),jit_textDef4(...)],...// updateRenderer function similar to a watcherfunction (ck, v) {var co = v.component;// gets current value for the component `name` propertyvar currVal_0 = co.model.name;// calls CheckAndUpdateNode function passing// currentView and node index (1) which uses// interpolated `currVal_0` valueck(v, 1, 0, currVal_0);});
}

因此,即使watcher的实现方式不同,但是digest 循环依旧存在。只是换了个名称而已。

在开发者模式中,tick()也会执行第二次以确保没有检测到其他改变。

我前面提到在angular.js中,digest是通过遍历watcher树并更新DOM的。在Anuglar中同样的事情也在发生。Angular通过遍历组件树并调用渲染更新函数来实现变化检测。这作为检测和更新视图过程的一部分,我已经在“你所要知道的所有关于Angular变化检测”中说的很详细。

正如Angular.js,在新版Angular中变化检测也是由异步事件触发。不同的是Angular使用zone接管了几乎所有异步事件,对于大部分异步事件而言无需手动触发变化检测。zone订阅了onMicrotaskEmpty事件,在每个异步事件完成后将获得通知。如果在当前VM轮询中没有microtasks需要执行(译者注2),那么这个事件就会被触发。当然,变化检测也可以通过view.detectChanges或者ApplicationRef.tick手动被执行。

Angular强迫使用自上而下的单项数据流(译者注3)。如果父组件的更改处理完毕了,那么子组件更新父组件的属性是不被允许的。 如果你在组件的DoCheck钩子中执行父组件属性的更新,这是可以的,因为这个生命周期的钩子在属性变化检测之前调用。但是这个操作在其他步骤执行,比如说,在AfterViewChecked钩子中,在开发者模式下就会有如下错误:Expression has changed after it was checked。想了解关于此类错误的更多信息,你可以阅读:你所需要知道的 ExpressionChangedAfterItHasBeenCheckedError错误

在生产环境中这不会报错,但Anuglar不会检测这些变化直到下一轮脏值检测。

使用生命周期的钩子来追踪变化

在angular.js中每个组件都定义了一系列的watchers来追踪以下内容:

* 父级组件的绑定* 自身组件属性* 计算值* 第三方插件

以下是这些功能在Angular中实现。为了跟踪父组件属性,我们现在可以使用OnChanges

我们可以使用DoCheck钩子来跟踪组件本身属性以及计算值属性。由于此钩子在当前组件上的Angular进程属性发生更改之前触发,因此我们可以根据需要执行任何操作,以便在UI中正确反映更改。

我们可以使用OnInit钩子来监听Angular生态系统之外的第三方插件,并手动运行变更检测。

例如,我们有一个显示当前时间的组件。时间由Time服务提供。下面是它将如何在Angular.js中实现的:

function link(scope, element) {scope.$watch(() => {return Time.getCurrentTime();}, (value) => {$scope.time = value;})
}

以下是在Angular中的实现:

class TimeComponent {ngDoCheck(){this.time = Time.getCurrentTime();}
}

另一个例子是,如果我们有第三方slider组件未集成到Angular生态系统中,但我们需要显示当前幻灯片,我们只需将此组件包装到角度组件中,changed 手动跟踪滑块的事件并手动触发摘要以反映UI中的更改:

function link(scope, element) {slider.on('changed', (slide) => {scope.slide = slide;// detect changes on the current component$scope.$digest();// or run change detection for the all app$rootScope.$digest();})
}

同样的思路也适用于Angular:

class SliderComponent {ngOnInit() {slider.on('changed', (slide) => {this.slide = slide// detect changes on the current component// this.cd is an injected ChangeDetector instancethis.cd.detectChanges();// or run change detection for the all app// this.appRef is an ApplicationRef instancethis.appRef.tick();})}
}

译者总结:

本文作者主要阐述了一个事实:digest依旧存在于Angular中,只是内部实现的方式有所不同。区别可以概括为一下几点:

  • 由于采用单项数据流,使得Angular可以自上而下的树型检测而不是像Angular.js那样需要循环检测(如下图所示),提升了执行效率(Angular.js需要循环检测10次,Angular只要一次),更多内容可以参考Victor Savkin在ng-conf的演讲,需翻墙

image

  • Angular使用zone.js接管了所有异步事件,使得脏值检测在异步事件中也无需手动触发。

译者注:

  1. 不可变对象
  2. 关于microtask,可以点击event loop查看,在Angular源码中,触发变化检测的基本流程是这样的:
    ngZone监听onMicrotaskEmpty事件,如果事件触发则执行tick(),摘录源码如下:

    this._zone.onMicrotaskEmpty.subscribe({next: () => { this._zone.run(() => { this.tick(); }); }});

    之后tick()在循环所有视图,并依此调用detectChanges

    tick(): void {if (this._runningTick) {throw new Error('ApplicationRef.tick is called recursively');}const scope = ApplicationRef._tickScope();try {this._runningTick = true;this._views.forEach((view) => view.detectChanges());if (this._enforceNoNewChanges) {this._views.forEach((view) => view.checkNoChanges());}} catch (e) {// Attention: Don't rethrow as it could cancel subscriptions to Observables!this._zone.runOutsideAngular(() => this._exceptionHandler.handleError(e));} finally {this._runningTick = false;wtfLeave(scope);}}
  3. 单项数据流。

    什么是单项数据流?顾名思义数据的流向是单一方向的,即数据是按照Model->Component->View的顺序流动的,这么做能够有效的保证数据的统一,Angular正是采用了这个原则,才能减少变化检测的次数。

    那么是不是意味着在Angular中就无法通过组件改变数据结构呢?显然不是这样的,只要在Angular开始渲染视图之前,改变都是允许的。

    举个例子:

    假设我们有一个组件cd,定义如下:

    import { Component,OnChanges,OnInit,DoCheck,AfterContentInit,AfterContentChecked,AfterViewInit,AfterViewChecked
    } from '@angular/core';@Component({selector: 'cd',template: `<span>计数器:{{count}}</span><ng-content></ng-content>`
    })
    export class CdComponent implements OnChanges,OnInit,DoCheck,AfterContentInit,AfterContentChecked,AfterViewInit,AfterViewChecked{//计数器count: number = 0;constructor(){}ngOnChanges(){ }ngOnInit(){ }ngDoCheck(){ }ngAfterContentInit(){ }ngAfterContentChecked(){ }ngAfterViewInit(){ }ngAfterViewChecked(){ }
    }

    假设现在要改变计数器的数值,实现的方式有很多种,在这里为了得到想要的结果,对比以下两种方式:

    在生命周期DoCheck这个钩子中实现:

    ngDoCheck(){ ++this.count; }

    在生命周期AfterViewInit这个钩子中实现:

    ngAfterViewInit(){ ++this.count; }

    两种方式都实现了数据的修改,但是第二种方式Angular会抛出错误提示,因为此时视图已经初始化完成,Angular不允许再修改数据。

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

相关文章

  1. Angular 2 Change Detection - 2

    更新时间 - 2017-03-20 16&#xff1a;15&#xff1b; 更新内容 - 我有话说模块在 Angular 2 Change Detection - 1 文章中&#xff0c;我们介绍了浏览器渲染、Zone、NgZone 的概念&#xff0c;本文将详细介绍 Angular 2 组件中的变化检测器。 组件和变化检测器 如你所知&#…...

    2024/4/21 3:19:09
  2. 深入理解ANGULAR中的$APPLY()以及$DIGEST()

    $apply()和$digest()在AngularJS中是两个核心概念&#xff0c;但是有时候它们又让人困惑。而为了了解AngularJS的工作方式&#xff0c;首先需要了解$apply()和$digest()是如何工作的。这篇文章旨在解释$apply()和$digest()是什么&#xff0c;以及在日常的编码中如何应用它们。 …...

    2024/4/20 22:09:30
  3. Angular 1 vs. Angular 2 深度比较

    AngularJS 2 尽管还在Alpha阶段&#xff0c;但主要功能和文档已经发布。让我我们了解下Angular 1 和 2 的区别&#xff0c;以及新的设计目标将如何实现。 Angular 2 当前仍处于 Alpha/开发预览阶段&#xff0c;但是主要功能和核心文档都已经可用了。让我们一起了解下 Angular 2…...

    2024/4/21 3:19:07
  4. Angular报错Cannot create property ‘validator‘ on string ‘XXX‘

    Angular报错Cannot create property ‘validator’ on string XXX’ 解决办法&#xff1a;<div [formGroup]"XXX"> 原因&#xff1a;formGroup少了一个[ ]...

    2024/4/21 3:19:06
  5. Angular的多种数据绑定方式

    Angular 提供了多种数据绑定方式。绑定类型可以分为三类&#xff0c;按数据流的方向分为&#xff1a; 从数据源到视图 从视图到数据源 双向&#xff1a;视图到数据源到视图 绑定类型 语法 分类 插值 属性 Attribute CSS 类 样式 {{expression}} [target]"expressio…...

    2024/4/21 3:19:05
  6. angular router-outlet的一个好用的功能

    今天做项目遇到了一个难题&#xff0c;就是在页面中有一个子路由通过router-outlet去展示&#xff0c;但是有一个需求&#xff0c;就是需要根据它的跳转来获取不同的数据&#xff0c;一开始想着使用Input&#xff0c;Output方法尝试一下(没错&#xff0c;vue里面就可以在路由里…...

    2024/4/21 3:19:05
  7. Angular $emit $broadcast $on controller的理解以及使用中出现的问题

    一般情况下&#xff0c;在项目中angular会被分割成两层controller&#xff0c;最外面的父级controller,以及父级下面的子级controller.如下&#xff1a; <!doctype html> <html ng-app"test"> <head><meta charset"utf-8"> </…...

    2024/4/21 3:19:03
  8. AngularJs 消息机制($emit、$broadcast、$on)

    1、发送消息必须配合事件如(ng-click)在回调函数中使用 2、$scope.$emit(名称,数据) 向自身以及父controller发送消息 3、$scope.$broadcast(名称,数据) 向自身以及子controller发送消息 4、$scope.$on(名称,function(event,data数据形参){...}) 接收消息代码示例: <html…...

    2024/4/21 3:19:02
  9. angularJs 父子作用域之间的通信—$on、 $emit、$broadcast的介绍

    angularJs中的作用域&#xff08;$scope&#xff09;结构和DOM结构非常相似&#xff0c;也是一个层次分明的树状结构。它有一个根作用域$rootscope&#xff08;对应angular应用或ng-app&#xff09;&#xff0c;其他作用域是嵌套在根作用域下面的。 angularJs的$scope之间都…...

    2024/4/20 20:09:17
  10. (精华)2020年8月4日 Angular 父组件和子组件相互传参

    一 &#xff1a;父组件获取子组件的数据和方法 也就是说 子组件给父组件传数据和方法 通过ViewChild 演示例子&#xff1a; 父组件&#xff1a;news 子组件&#xff1a;header 假如子组件header有个run方法 run(){ console.log(‘我是header里面的run方法’); } 在父组件调用…...

    2024/4/20 6:05:54
  11. Vue组件之props,emit与on以及slot分发详解

    Vue组件实例之间的作用域是孤立存在&#xff0c;要让它们之间的信息互通&#xff0c;就必须采用组件的通信方式。 props用于父组件向子组件传达信息 1.静态方式 例如&#xff1a; <div id"app"><my-component message"hello"></my-compo…...

    2024/4/20 20:09:14
  12. angular 组件通信_Angular中的组件通信

    angular 组件通信In this post, I am going to share a few methods to pass data between components in Angular and which is the best way depending upon the scenario. 在本文中&#xff0c;我将分享一些方法来在Angular的组件之间传递数据&#xff0c;这是根据情况而定的…...

    2024/4/20 20:09:18
  13. 子作用域发送数据给父作用域 $on $emit

    直接贴代码 <title>无标题文档</title> <style>#father{width:500px;height:300px;border:2px solid #ccc;}#child{width:200px;height:200px;border:1px dashed #000;} </style> </head> <script src"angular-1.6.8/angular.js"&…...

    2024/4/20 20:09:13
  14. Angular cdk 学习之 Overlay

    cdk Overlay主要用来实现在界面上创建浮动面板&#xff0c;例如弹窗(Dialog)&#xff0c;下拉框(select)等等都可以通过cdk Overlay来实现。接下来咱们将对Overlay的使用做一个非常简单的介绍。特别推荐大家直接去看官网&#xff0c;官网是最详细的也是最好的文档https://mater…...

    2024/4/20 20:09:12
  15. angular随手笔记

    AngularJS用法&#xff1a; AngularJS 指令: AngularJS 通过被称为 指令 的新属性来扩展 HTML。 AngularJS 指令是扩展的 HTML 属性&#xff0c;带有前缀 ng-。 ng-app 指令初始化一个 AngularJS 应用程序。 ng-init 指令初始化应用程序数据。 ng-model 指令把元素值&…...

    2024/4/20 20:09:11
  16. angular6入门实战,环境搭建、添加组件、服务、路由和HTTP

    目录 一、新建web项目 二、启动项目 三、添加表格&#xff0c;css控制隔行变色 四、创建组件 五、显示列表 创建模拟数据 导入 用* ngFor 列出 使用* ngIf 隐藏空白详细信息 设置所选样式 添加单击事件绑定 添加单击事件处理程序 六、主/明细组件 建立HeroDetail…...

    2024/4/20 20:09:09
  17. Angular之Http+RxJS之WebSocket(网络必备)

    Get data from a server 在本教程中&#xff0c;您将在Angular的HttpClient的帮助下添加以下数据持久性特性。HeroService通过HTTP请求获取英雄数据。用户可以通过HTTP添加、编辑和删除英雄并保存这些更改。用户可以通过名字搜索英雄。 一、 启用HTTP服务 HttpClient是Angula…...

    2024/4/21 3:19:02
  18. Angular的学习笔记

    Angular的学习笔记 ng-app""定义Angular的使用的范围。 ng-model“变量”&#xff0c;定义变量名。 ng-bind“变量”&#xff0c;绑定变量名&#xff0c;获取该变量的数据。 ng-init“变量值&#xff1b;变量值” 初始化变量的值&#xff0c;有多个变量时&#x…...

    2024/4/23 6:18:43
  19. Angular 滚动条 angular-nice-bar

    angular-nice-bar 详细介绍 一个轻量级的Angular scrollbar. Install bower install angular-nice-bar --save Usage <link rel"stylesheet" href"bower_components/angular-nice-bar/dist/css/angular-nice-bar.css" /><script src"bo…...

    2024/4/21 3:19:00
  20. angular2 html转义,Angular2:组件输入中的转义字符(Angular2: Escape character in component's input)...

    Angular2&#xff1a;组件输入中的转义字符(Angular2: Escape character in components input)我有以下代码&#xff1a;我已经尝试了许多东西( &#xff0c; \ &#xff0c; \\ &#xff0c; \ &#xff0c;......)以逃避 in&#xff0c;但我没有设法做到这一点。 我怎样才能…...

    2024/4/21 3:19:03

最新文章

  1. 设计模式-观察者模式(Observer Pattern)结构|原理|优缺点|场景|示例

    观察者模式&#xff08;Observer Pattern&#xff09;是一种行为型设计模式&#xff0c;它定义了一种一对多的依赖关系&#xff0c;允许一个或多个观察者对象订阅主题对象&#xff0c;当主题对象状态发生改变时&#xff0c;会通知所有已订阅的观察者对象&#xff0c;使得它们能…...

    2024/4/25 18:32:40
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/3/20 10:50:27
  3. 最新AI智能系统ChatGPT网站源码V6.3版本,GPTs、AI绘画、AI换脸、垫图混图+(SparkAi系统搭建部署教程文档)

    一、前言 SparkAi创作系统是基于ChatGPT进行开发的Ai智能问答系统和Midjourney绘画系统&#xff0c;支持OpenAI-GPT全模型国内AI全模型。本期针对源码系统整体测试下来非常完美&#xff0c;那么如何搭建部署AI创作ChatGPT&#xff1f;小编这里写一个详细图文教程吧。已支持GPT…...

    2024/4/25 2:00:46
  4. 基于深度学习的机场航拍小目标检测系统(网页版+YOLOv8/v7/v6/v5代码+训练数据集)

    摘要&#xff1a;在本博客中介绍了基于YOLOv8/v7/v6/v5的机场航拍小目标检测系统。该系统的核心技术是采用YOLOv8&#xff0c;并整合了YOLOv7、YOLOv6、YOLOv5算法&#xff0c;从而进行性能指标的综合对比。我们详细介绍了国内外在机场航拍小目标检测领域的研究现状、数据集处理…...

    2024/4/20 17:47:06
  5. 【外汇早评】美通胀数据走低,美元调整

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

    2024/4/25 11:51:20
  6. 【原油贵金属周评】原油多头拥挤,价格调整

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

    2024/4/23 13:30:22
  7. 【外汇周评】靓丽非农不及疲软通胀影响

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

    2024/4/23 13:28:06
  8. 【原油贵金属早评】库存继续增加,油价收跌

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

    2024/4/24 18:16:28
  9. 【外汇早评】日本央行会议纪要不改日元强势

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

    2024/4/23 13:27:44
  10. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

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

    2024/4/19 11:57:53
  11. 【外汇早评】美欲与伊朗重谈协议

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

    2024/4/23 13:29:53
  12. 【原油贵金属早评】波动率飙升,市场情绪动荡

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

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

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

    2024/4/25 13:39:44
  14. 【原油贵金属早评】市场情绪继续恶化,黄金上破

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

    2024/4/23 22:01:21
  15. 【外汇早评】美伊僵持,风险情绪继续升温

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

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

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

    2024/4/25 0:00:17
  17. 氧生福地 玩美北湖(上)——为时光守候两千年

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

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

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

    2024/4/19 11:59:23
  19. 氧生福地 玩美北湖(下)——奔跑吧骚年!

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

    2024/4/19 11:59:44
  20. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

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

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

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

    2024/4/24 16:38:05
  22. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

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

    2024/4/25 13:19:01
  23. 广州械字号面膜生产厂家OEM/ODM4项须知!

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

    2024/4/23 13:27:51
  24. 械字号医用眼膜缓解用眼过度到底有无作用?

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

    2024/4/23 13:27:19
  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