freemaker 课程
品优购电商系统开发
第12章
网页静态化解决方案-Freemarker
传智播客.黑马程序员
1.网页静态化技术Freemarker
1.1为什么要使用网页静态化技术
网页静态化解决方案在实际开发中运用比较多,例如新闻网站,门户网站中的新闻频道或者是文章类的频道。
对于电商网站的商品详细页来说,至少几百万个商品,每个商品又有大量的信息,这样的情况同样也适用于使用网页静态化来解决。
网页静态化技术和缓存技术的共同点都是为了减轻数据库的访问压力,但是具体的应用场景不同,缓存比较适合小规模的数据,而网页静态化比较适合大规模且相对变化不太频繁的数据。另外网页静态化还有利于SEO。
另外我们如果将网页以纯静态化的形式展现,就可以使用Nginx这样的高性能的web服务器来部署。Nginx可以承载5万的并发,而Tomcat只有几百。关于Nginx我们在后续的课程中会详细讲解。
今天我们就研究网页静态化技术----Freemarker 。
1.2什么是 Freemarker
FreeMarker 是一个用 Java 语言编写的模板引擎,它基于模板来生成文本输出。FreeMarker与 Web 容器无关,即在 Web 运行时,它并不知道 Servlet 或 HTTP。它不仅可以用作表现层的实现技术,而且还可以用于生成 XML,JSP 或 Java 等。
1.3 Freemarker入门小DEMO
1.3.1工程引入依赖
<dependencies> <dependency> <groupId>org.freemarker</groupId> <artifactId>freemarker</artifactId> <version>2.3.23</version> </dependency> </dependencies> <build> <plugins> <!-- java编译插件 --> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.2</version> <configuration> <source>1.7</source> <target>1.7</target> <encoding>UTF-8</encoding> </configuration> </plugin> </plugins> </build> |
1.3.2创建模板文件
模板文件中四种元素
1、文本,直接输出的部分
2、注释,即<#--...-->格式不会输出
3、插值(Interpolation):即${..}部分,将使用数据模型中的部分替代输出
4、FTL指令:FreeMarker指令,和HTML标记类似,名字前加#予以区分,不会输出。
我们现在就创建一个简单的创建模板文件test.ftl
<html> <head> <meta charset="utf-8"> <title>Freemarker入门小DEMO </title> </head> <body> <#--我只是一个注释,我不会有任何输出 --> ${name},你好。${message} </body> </html> |
这里有文本、插值和注释
1.3.3生成文件
使用步骤:
第一步:创建一个 Configuration 对象,直接 new 一个对象。构造方法的参数就是 freemarker的版本号。
第二步:设置模板文件所在的路径。
第三步:设置模板文件使用的字符集。一般就是 utf-8.
第四步:加载一个模板,创建一个模板对象。
第五步:创建一个模板使用的数据集,可以是 pojo 也可以是 map。一般是 Map。
第六步:创建一个 Writer 对象,一般创建一 FileWriter 对象,指定生成的文件名。
第七步:调用模板对象的 process 方法输出文件。
第八步:关闭流
代码:
创建Test类 main方法如下:
public static void main(String[] args) throws Exception{ //1.创建配置类 Configuration configuration=new Configuration(Configuration.getVersion()); //2.设置模板所在的目录 String dir = "D:\\workspacepyg\\spring-demo-freemarker\\src\\main\\resources\\"; configuration.setDirectoryForTemplateLoading(new File(dir)); //3.设置字符集 configuration.setDefaultEncoding("utf-8"); //4.加载模板 Template template = configuration.getTemplate("test.ftl"); //5.创建数据模型 Map map=new HashMap(); map.put("name", "张三 "); map.put("message", "欢迎来到神奇的品优购世界!"); //6.创建Writer对象 Writer out =new FileWriter(new File(dir + "test.html")); //7.输出 template.process(map, out); //8.关闭Writer对象 out.close(); } |
执行后,在D盘根目录即可看到生成的test.html ,打开看看
是不是有些小激动呢?
1.4 FTL指令
1.4.1 assign指令
此指令用于在页面上定义一个变量
(1)定义简单类型:
<#assign linkman="周先生"> 联系人:${linkman} |
(2)定义对象类型:
<#assign info={"mobile":"13301231212",'address':'北京市昌平区王府街'} > 电话:${info.mobile} 地址:${info.address} |
运行效果:
1.4.2 include指令
此指令用于模板文件的嵌套
创建模板文件head.ftl
<h1>黑马信息网</h1> |
我们修改test.ftl,在模板文件中使用include指令引入刚才我们建立的模板
<#include "head.ftl"> |
1.4.3 if指令
在模板文件上添加
<#if success> 你已通过实名认证 <#else> 你未通过实名认证 </#if> |
在代码中对str变量赋值
map.put("success", true); |
在freemarker的判断中,可以使用= 也可以使用==
1.4.4 list指令
需求,实现商品价格表,如下图:
(1)代码中对变量goodsList赋值
List goodsList=new ArrayList(); Map goods1=new HashMap(); goods1.put("name", "苹果"); goods1.put("price", 5.8); Map goods2=new HashMap(); goods2.put("name", "香蕉"); goods2.put("price", 2.5); Map goods3=new HashMap(); goods3.put("name", "橘子"); goods3.put("price", 3.2); goodsList.add(goods1); goodsList.add(goods2); goodsList.add(goods3); map.put("goodsList", goodsList); |
(2)在模板文件上添加
----商品价格表----<br> <#list goodsList as goods> ${goods_index+1} 商品名称: ${goods.name} 价格:${goods.price}<br> </#list> |
如果想在循环中得到索引,使用循环变量+_index就可以得到。
1.5 内建函数
+
内建函数语法格式: 变量+?+函数名称
1.5.1获取集合大小
我们通常要得到某个集合的大小,如下图:
我们使用size函数来实现,代码如下:
共 ${goodsList?size} 条记录 |
1.5.2转换JSON字符串为对象
我们通常需要将json字符串转换为对象,那如何处理呢?看代码
<#assign text="{'bank':'工商银行','account':'10101920201920212'}" /> <#assign data=text?eval /> 开户行:${data.bank} 账号:${data.account} |
1.5.3日期格式化
代码中对变量赋值:
map.put("today", new Date()); |
在模板文件中加入
当前日期:${today?date} <br> 当前时间:${today?time} <br> 当前日期+时间:${today?datetime} <br> 日期格式化: ${today?string("yyyy年MM月")} |
运行效果如下:
1.5.4数字转换为字符串
代码中对变量赋值:
map.put("point", 102920122); |
修改模板:
累计积分:${point} |
页面显示:
我们会发现数字会以每三位一个分隔符显示,有些时候我们不需要这个分隔符,就需要将数字转换为字符串,使用内建函数c
累计积分:${point?c} |
页面显示效果如下:
1.6空值处理运算符
如果你在模板中使用了变量但是在代码中没有对变量赋值,那么运行生成时会抛出异常。但是有些时候,有的变量确实是null,怎么解决这个问题呢?
1.6.1判断某变量是否存在:“??”
用法为:variable??,如果该变量存在,返回true,否则返回false
<#if aaa??> aaa变量存在 <#else> aaa变量不存在 </#if> |
1.6.2缺失变量默认值:“!”
我们除了可以判断是否为空值,也可以使用!对null值做转换处理
在模板文件中加入
${aaa!'-'} |
在代码中不对aaa赋值,也不会报错了 ,当aaa为null则返回!后边的内容-
1.7运算符
1.7.1算数运算符
FreeMarker表达式中完全支持算术运算,FreeMarker支持的算术运算符包括:+, - , * , / , %
1.7.2逻辑运算符
逻辑运算符有如下几个:
逻辑与:&&
逻辑或:||
逻辑非:!
逻辑运算符只能作用于布尔值,否则将产生错误
1.7.3比较运算符
表达式中支持的比较运算符有如下几个:
1 =或者==:判断两个值是否相等.
2 !=:判断两个值是否不等.
3 >或者gt:判断左边值是否大于右边值
4 >=或者gte:判断左边值是否大于等于右边值
5 <或者lt:判断左边值是否小于右边值
6 <=或者lte:判断左边值是否小于等于右边值
注意: =和!=可以用于字符串,数值和日期来比较是否相等,但=和!=两边必须是相同类型的值,否则会产生错误,而且FreeMarker是精确比较,"x","x ","X"是不等的.其它的运行符可以作用于数字和日期,但不能作用于字符串,大部分的时候,使用gt等字母运算符代替>会有更好的效果,因为 FreeMarker会把>解释成FTL标签的结束字符,当然,也可以使用括号来避免这种情况,如:<#if (x>y)>
2.商品详情页-数据显示
2.1需求分析
运用Freemarker技术来实现商品详细页的静态化。通过地址栏输入某地址,如下形式
http://localhost:9001/149187842867973.html
能在本地电脑某目录生成商品详细页,页面的名称为商品id.html
2.2工程搭建
2.2.1服务接口层
在interface工程下创建接口ItemPageService
2.2.2服务实现层
(1)工程service-sellergoods
(2)添加web.xml 参见其它服务工程
(3)spring配置文件 参见其它服务工程 ,另外配置:
<bean id="freemarkerConfig" class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer"> <property name="templateLoaderPath" value="/WEB-INF/ftl/" /> <property name="defaultEncoding" value="UTF-8" /> </bean> |
(4)建立cn.itcast.core.service包,包下建立类
/** * 生成商品详情页面 * @author lx * */ @Service public class ItemPageServiceImpl implements ItemPageService,ServletContextAware{
@Autowired private FreeMarkerConfigurer freeMarkerConfigurer;
@Autowired private GoodsDao goodsDao; @Autowired private GoodsDescDao goodsDescDao; @Autowired private ItemDao itemDao; @Autowired private ItemCatDao itemCatDao;
//通过商品ID 生成商品详情页面 public void genItemHtml(Long goodsId){ Map<String,Object> root = new HashMap<String,Object>(); //商品表 SPU 小字段 Goods goods = goodsDao.selectByPrimaryKey(goodsId); root.put("goods", goods); //商品详情表 SPU 大字段 root.put("goodsDesc", goodsDescDao.selectByPrimaryKey(goodsId)); //商品表结果集SKU ItemQuery itemQuery = new ItemQuery(); itemQuery.createCriteria().andGoodsIdEqualTo(goodsId).andStatusEqualTo("1"); List<Item> itemList = itemDao.selectByExample(itemQuery); root.put("itemList", itemList); root.put("itemCat1", itemCatDao.selectByPrimaryKey(goods.getCategory1Id()).getName()); root.put("itemCat2", itemCatDao.selectByPrimaryKey(goods.getCategory2Id()).getName()); root.put("itemCat3", itemCatDao.selectByPrimaryKey(goods.getCategory3Id()).getName());
//Freemarker Configuration configuration = freeMarkerConfigurer.getConfiguration(); //静态页面生成的真实路径 String realPath = getRealPath(goodsId + ".html"); Writer out = null; try { Template template = configuration.getTemplate("item.ftl"); //流 out = new FileWriter(new File(realPath)); template.process(root, out); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); }finally { if(null != out){ try { out.close(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
}
/** * 返回真实路径 * @param path * @return */ private String getRealPath(String path) { return servletContext.getRealPath(path); } private ServletContext servletContext; @Override public void setServletContext(ServletContext servletContext) { // TODO Auto-generated method stub this.servletContext = servletContext; } } |
(5) 拷贝js,css等静态资源到page-service的webapp目录下
(6)将item.html拷贝至/WEB-INF/ftl下 ,修改扩展名为ftl ,将商品名称用插值代替
<div class="sku-name"> <h4>${goods.goodsName}</h4> </div> |
(7)生成的文件在eclipse工作空间的.metadata\.plugins\org.eclipse.wst.server.core\tmp\wtpwebapps目录下
2.3商品详情页模板构建
2.3.1模板模块化引入
此时我们的item.ftl内容较多,当我们编辑时不容易快速找到编辑的位置,所以我们将头部分拆分到head.ftl ,将尾部拆分到foot.ftl ,用include指令在item.ftl中引入 。
内容详见配套代码
2.3.2生成基本数据
在模板中找到合适的位置,用插值替换静态文本
<div class="news"><span>${goods.caption}</span></div> |
<div class="fl price"><i>¥</i><em>${goods.price}</em><span>降价通知</span></div> |
<div class="intro-detail"><!-- 商品详情 --> ${goodsDesc.introduction}</div> |
<div id="two" class="tab-pane"><p>${goodsDesc.packageList}</p></div> <div id="three" class="tab-pane"><p>${goodsDesc.saleService}</p></div> |
运行控制层代码,测试生成效果
http://localhost:9001/149187842867973.html
2.3.3生成图片列表
编辑模板文件
<#--图片列表 --> <#assign imageList=goodsDesc.itemImages?eval /> |
这一句要转换图片列表的json字符串
图片部分的代码
<!--默认第一个预览--> <div id="preview" class="spec-preview"> <span class="jqzoom"> <#if (imageList?size>0)> <img jqimg="${imageList[0].url}" src="${imageList[0].url}" width="400px" height="400px" /> </#if> </span> </div> <!--下方的缩略图--><div class="spec-scroll"> <div class="items"> <ul> <#list imageList as item> <li><img src="${item.url}" bimg="${item.url}" onmousemove="preview(this)" /></li> </#list> </ul> </div> </div> |
生成效果如下:
2.3.4生成扩展属性列表
修改模板 首先进行json转换
<#--扩展属性列表 --> <#assign customAttributeList=goodsDesc.customAttributeItems?eval /> |
显示扩展属性数据,如果扩展属性为空则不显示此条数据
<#list customAttributeList as item> <#if item.value??> <li>${item.text} :${item.value}</li> </#if> </#list> |
2.3.5生成规格列表
修改模板 转换规格列表
<#--规格列表 --> <#assign specificationList=goodsDesc.specificationItems?eval /> |
此时,我们需要使用嵌套循环
<#list specificationList as specification> <dl> <dt> <div class="fl title"> <i>${specification.attributeName}</i> </div> </dt> <#list specification.attributeValue as item> <dd><a href="javascript:;" >${item}</a></dd> </#list> </dl> </#list> |
修改模板,展示商品分类面包屑
<ul class="sui-breadcrumb"> <li><a href="#">${itemCat1}</a></li> <li><a href="#">${itemCat2}</a></li> <li><a href="#">${itemCat3}</a></li> </ul> |
3.商品详情页-前端逻辑
3.1购买数量加减操作
3.1.1加入angularJS库
将angularJS库加入d:\item下
3.1.2前端控制层
将base.js拷贝到page-service项目js目录下
在js目录下构建controller文件夹,创建itemController.js
//商品详细页(控制层) app.controller('itemController',function($scope){ //数量操作 $scope.addNum=function(x){ $scope.num=$scope.num+x; if($scope.num<1){ $scope.num=1; } } }); |
在方法中控制数量不能小于1
3.1.3模板
引入js
<script type="text/javascript" src="plugins/angularjs/angular.min.js"> </script> <script type="text/javascript" src="js/base.js"> </script> <script type="text/javascript" src="js/controller/itemController.js"> </script> |
添加指令
<body ng-app="pinyougou" ng-controller="itemController" ng-init="num=1"> |
调用操作数量的方法
<div class="controls"> <input autocomplete="off" type="text" value="{{num}}" minnum="1" class="itxt" /> <a href="javascript:void(0)" class="increment plus" ng-click="addNum(1)" >+</a> <a href="javascript:void(0)" class="increment mins" ng-click="addNum(-1)">-</a> </div> |
3.2规格选择
最终我们需要实现的效果:
3.2.1前端控制层
修改itemController.js
$scope.specificationItems={};//记录用户选择的规格 //用户选择规格 $scope.selectSpecification=function(name,value){ $scope.specificationItems[name]=value; } //判断某规格选项是否被用户选中 $scope.isSelected=function(name,value){ if($scope.specificationItems[name]==value){ return true; }else{ return false; } } |
3.2.2模板
页面调用控制器的方法
<dd> <a class="{{isSelected('${specification.attributeName}','${item}')?'selected':''}}" ng-click="selectSpecification('${specification.attributeName}','${item}')"> ${item} <span title="点击取消选择"> </span> </a> </dd> |
4.商品详情页-读取SKU信息
需求:当我们选择规格后,应该在页面上更新商品名称为SKU的商品标题,价格也应该为SKU的商品价格。
4.1模板
修改模板:
<script> //SKU商品列表 var skuList=[ <#list itemList as item> { "id":${item.id?c}, "title":"${item.title!''}", "price":${item.price?c}, "spec": ${item.spec} } , </#list> ]; </script> |
测试生成,发现页面源代码中生成了变量
4.2显示SKU标题和价格
4.2.1加载默认SKU信息
修改itemController.js
//加载默认SKU $scope.loadSku=function(){ $scope.sku=skuList[0]; $scope.specificationItems= JSON.parse(JSON.stringify($scope.sku.spec)) ; } |
修改模板item.ftl
<body ng-app="pinyougou" ng-controller="itemController" ng-init="num=1;loadSku()"> |
修改模板,显示标题
<div class="sku-name"><h4>{{sku.title}}</h4></div> |
显示价格
<div class="summary-wrap"> <div class="fl title"><i>价 格</i></div> <div class="fl price"><i>¥</i> <em>{{sku.price}}</em> <span>降价通知</span></div> </div> |
4.2.2选择规格更新SKU
修改itemController.js , 编写匹配对象的方法
//匹配两个对象 matchObject=function(map1,map2){ for(var k in map1){ if(map1[k]!=map2[k]){ return false; } } for(var k in map2){ if(map2[k]!=map1[k]){ return false; } } return true; } |
编写方法,在SKU列表中查询当前用户选择的SKU
//查询SKU searchSku=function(){ for(var i=0;i<skuList.length;i++ ){ if( matchObject(skuList[i].spec ,$scope.specificationItems ) ){ $scope.sku=skuList[i]; return ; } } $scope.sku={id:0,title:'--------',price:0};//如果没有匹配的 } |
在用户选择规格后触发读取方法
//用户选择规格 $scope.selectSpecification=function(name,value){ $scope.specificationItems[name]=value; searchSku();//读取sku } |
4.3添加商品到购物车
修改itemController.js
//添加商品到购物车 $scope.addToCart=function(){ alert('skuid:'+$scope.sku.id); } |
修改模板:
<li><a href="#" target="_blank" class="sui-btn btn-danger addshopcar" ng-click="addToCart()">加入购物车</a></li> |
5.系统模块对接
5.1运营商后台调用页面生成服务
修改sellerGoods项目的GoodsServiceImpl.java
@Autowired private ItemPageService itemPageService; //更新状态 审核通过 或驳回 public void updateStatus(Long[] ids,String status){ Goods goods = new Goods(); goods.setAuditStatus(status); for (Long id : ids) { goods.setId(id); goodsDao.updateByPrimaryKeySelective(goods); //判断是否为审核通过 if("1".equals(status)){ //保存商品信息到索引库 importList(id); //静态化 itemPageService.genItemHtml(id); } }
} |
5.2 搜索系统与商品详细页对接
修改search-web 的search.html,修改点击图片的链接为http://localhost:9001/{{item.goodsId}}.html
说明:商品详细页是静态页,所以在开发阶段我们可以使用tomcat来进行测试。部署在生产环境是部署在Nginx中。
转载于:https://www.cnblogs.com/shan1393/p/9425474.html
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
相关文章
- 双眼皮去皮眼尾耸拉
...
2024/4/21 16:45:41 - 双眼皮前眼角过短图片
...
2024/4/21 16:45:39 - 双眼皮皮下增生
...
2024/4/21 16:45:38 - 双眼皮能不难做
...
2024/4/20 14:15:18 - 双眼皮埋线有什么缺点
...
2024/4/20 14:15:15 - 双眼皮埋下哪家好
...
2024/4/20 14:15:15 - 双眼皮埋的线会吸收吗
...
2024/4/20 14:15:13 - 《菜鸟教程》| Egret微信小游戏好友排行榜教程
写在前面:随着越来越多的新人开始接触白鹭引擎,创作属于自己的游戏。考虑到初学者会遇到一些实际操作问题,我们近期整理推出“菜鸟”系列技术文档,以便更好的让这些开发者们快速上手,Egret大神们可以自动忽略此类内容。今天我们分享的菜鸟文档将介绍微信小游戏好友排行榜的…...
2024/4/28 6:49:27 - 双眼皮两到印子图片
...
2024/5/5 4:02:15 - 双眼皮宽凹
...
2024/5/1 22:35:14 - 双眼皮济南美莱
...
2024/4/25 10:53:24 - 双眼皮恢复期间大小眼
...
2024/5/3 2:57:02 - 双眼皮恢复后眼睑太厚
...
2024/5/2 23:43:20 - 双眼皮恢复后上眼睑厚
...
2024/4/21 16:45:35 - 双眼皮后上眼睑肿厚
...
2024/5/4 7:55:31 - 双眼皮红印子
...
2024/5/4 4:58:11 - 双眼皮痕迹明显怎么办
...
2024/4/20 17:50:14 - Angularjs 留存(三)
PS:AngularJS留存系列主要是用来记录一些自己在学习其他文章时觉得有必要留存一下的fortune! 文章可能会很长(默认每篇17个小的知识点),但是我们可以使用Ctrl F 来查找啦! 1、$parse/$eval和$observe/$watch如何区分 $parse和$e…...
2024/4/21 16:45:32 - Angular4学习笔记(四)
(一)依赖注入(用依赖注入实现以下的界面) 1. 创建一个product1组件和一个product服务。 2.先写product服务 product.service.ts import { Injectable } from angular/core;Injectable() export class ProductService {construct…...
2024/5/3 23:51:03 - 双眼皮割完上眼皮太厚
...
2024/5/4 8:02:56
最新文章
- QT5之windowswidget_菜单栏+工具栏_核心控件_浮动窗口_模态对话框_标准对话框/文本对话框
菜单栏工具栏 新建工程基类是QMainWindow 1、 2、 3、 点.pro文件,添加配置 因为之后用到lambda; 在.pro文件添加配置c11 CONFIG c11 #不能加分号 添加头文件 #include <QMenuBar>//菜单栏的头文件 主窗口代码mainwindow.cpp文件 #include &q…...
2024/5/5 6:59:26 - 梯度消失和梯度爆炸的一些处理方法
在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...
2024/3/20 10:50:27 - dp小兰走迷宫
昨天学习了bfs的基本概念,今天来做一道经典习题练练手吧! bfs常用的两类题型 1.从A出发是否存在到达B的路径(dfs也可) 2.从A出发到B的最短路径(数小:<20才能用dfs) 遗留的那个问题的答案- 题目:走迷宫 #incl…...
2024/5/4 16:36:43 - C++ 【原型模式】
简单介绍 原型模式是一种创建型设计模式 | 它使你能够复制已有对象,客户端不需要知道要复制的对象是哪个类的实例,只需通过原型工厂获取该对象的副本。 以后需要更改具体的类或添加新的原型类,客户端代码无需改变,只需修改原型工…...
2024/5/1 7:27:36 - 【外汇早评】美通胀数据走低,美元调整
原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...
2024/5/4 23:54:56 - 【原油贵金属周评】原油多头拥挤,价格调整
原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...
2024/5/4 23:54:56 - 【外汇周评】靓丽非农不及疲软通胀影响
原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...
2024/5/4 23:54:56 - 【原油贵金属早评】库存继续增加,油价收跌
原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...
2024/5/4 23:55:17 - 【外汇早评】日本央行会议纪要不改日元强势
原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...
2024/5/4 23:54:56 - 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响
原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...
2024/5/4 23:55:05 - 【外汇早评】美欲与伊朗重谈协议
原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...
2024/5/4 23:54:56 - 【原油贵金属早评】波动率飙升,市场情绪动荡
原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...
2024/5/4 23:55:16 - 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试
原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...
2024/5/4 23:54:56 - 【原油贵金属早评】市场情绪继续恶化,黄金上破
原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...
2024/5/4 18:20:48 - 【外汇早评】美伊僵持,风险情绪继续升温
原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...
2024/5/4 23:54:56 - 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势
原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...
2024/5/4 23:55:17 - 氧生福地 玩美北湖(上)——为时光守候两千年
原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...
2024/5/4 23:55:06 - 氧生福地 玩美北湖(中)——永春梯田里的美与鲜
原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...
2024/5/4 23:54:56 - 氧生福地 玩美北湖(下)——奔跑吧骚年!
原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...
2024/5/4 23:55:06 - 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!
原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...
2024/5/4 2:59:34 - 「发现」铁皮石斛仙草之神奇功效用于医用面膜
原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...
2024/5/4 23:55:16 - 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者
原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...
2024/5/4 23:54:58 - 广州械字号面膜生产厂家OEM/ODM4项须知!
原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...
2024/5/4 23:55:01 - 械字号医用眼膜缓解用眼过度到底有无作用?
原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...
2024/5/4 23:54:56 - 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...
解析如下:1、长按电脑电源键直至关机,然后再按一次电源健重启电脑,按F8健进入安全模式2、安全模式下进入Windows系统桌面后,按住“winR”打开运行窗口,输入“services.msc”打开服务设置3、在服务界面,选中…...
2022/11/19 21:17:18 - 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。
%读入6幅图像(每一幅图像的大小是564*564) 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 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...
win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面,在等待界面中我们需要等待操作结束才能关机,虽然这比较麻烦,但是对系统进行配置和升级…...
2022/11/19 21:17:15 - 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...
有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows,请勿关闭计算机”的提示,要过很久才能进入系统,有的用户甚至几个小时也无法进入,下面就教大家这个问题的解决方法。第一种方法:我们首先在左下角的“开始…...
2022/11/19 21:17:14 - win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...
置信有很多用户都跟小编一样遇到过这样的问题,电脑时发现开机屏幕显现“正在配置Windows Update,请勿关机”(如下图所示),而且还需求等大约5分钟才干进入系统。这是怎样回事呢?一切都是正常操作的,为什么开时机呈现“正…...
2022/11/19 21:17:13 - 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...
Win7系统开机启动时总是出现“配置Windows请勿关机”的提示,没过几秒后电脑自动重启,每次开机都这样无法进入系统,此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一:开机按下F8,在出现的Windows高级启动选…...
2022/11/19 21:17:12 - 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...
有不少windows10系统用户反映说碰到这样一个情况,就是电脑提示正在准备windows请勿关闭计算机,碰到这样的问题该怎么解决呢,现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法:1、2、依次…...
2022/11/19 21:17:11 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...
今天和大家分享一下win7系统重装了Win7旗舰版系统后,每次关机的时候桌面上都会显示一个“配置Windows Update的界面,提示请勿关闭计算机”,每次停留好几分钟才能正常关机,导致什么情况引起的呢?出现配置Windows Update…...
2022/11/19 21:17:10 - 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...
只能是等着,别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚,只能是考虑备份数据后重装系统了。解决来方案一:管理员运行cmd:net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...
2022/11/19 21:17:09 - 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?
原标题:电脑提示“配置Windows Update请勿关闭计算机”怎么办?win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢?一般的方…...
2022/11/19 21:17:08 - 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...
关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!关机提示 windows7 正在配…...
2022/11/19 21:17:05 - 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...
钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...
2022/11/19 21:17:05 - 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...
前几天班里有位学生电脑(windows 7系统)出问题了,具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面,长时间没反应,无法进入系统。这个问题原来帮其他同学也解决过,网上搜了不少资料&#x…...
2022/11/19 21:17:04 - 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...
本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法,并在最后教给你1种保护系统安全的好方法,一起来看看!电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中,添加了1个新功能在“磁…...
2022/11/19 21:17:03 - 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...
许多用户在长期不使用电脑的时候,开启电脑发现电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机。。.这要怎么办呢?下面小编就带着大家一起看看吧!如果能够正常进入系统,建议您暂时移…...
2022/11/19 21:17:02 - 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...
配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!配置windows update失败 还原更改 请勿关闭计算机&#x…...
2022/11/19 21:17:01 - 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...
不知道大家有没有遇到过这样的一个问题,就是我们的win7系统在关机的时候,总是喜欢显示“准备配置windows,请勿关机”这样的一个页面,没有什么大碍,但是如果一直等着的话就要两个小时甚至更久都关不了机,非常…...
2022/11/19 21:17:00 - 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...
当电脑出现正在准备配置windows请勿关闭计算机时,一般是您正对windows进行升级,但是这个要是长时间没有反应,我们不能再傻等下去了。可能是电脑出了别的问题了,来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...
2022/11/19 21:16:59 - 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...
我们使用电脑的过程中有时会遇到这种情况,当我们打开电脑之后,发现一直停留在一个界面:“配置Windows Update失败,还原更改请勿关闭计算机”,等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢࿰…...
2022/11/19 21:16:58 - 如何在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