- Reactor框架介绍,和使用示例
Reactor框架介绍Reactor是一个基于JVM的非阻塞响应式编程框架,遵循ReactiveStreams规范,专为构建高并发、低延迟的异步应用设计[2][4]。其核心特点包括:异步流处理提供Flux(处理0或N个元素)和Mono(处理0或1个元素)两个核心抽象,支持链式操作(如map、filter、flatMap等)实现数据的异步处理[5][4]。背压支持通过ReactiveStreams协
- Excel VBA属性、方法、事件大全——Part13(Complete List of Excel VBA attribute/method and event)
预见未来to50
对象/属性/方法/事件(Object/Attribute/Method/Event)描述(Description)Save保存指定工作簿所做的更改本示例保存当前活动工作簿。ActiveWorkbook.Save本示例保存所有打开的工作簿,然后关闭MicrosoftExcel。ForEachwInApplication.Workbooksw.SaveNextwApplication.QuitSave
- ref() 与 reactive()
前端岳大宝
前端框架Vuejavascript前端vue.js
下面,我们来系统的梳理关于ref()与reactive()的基本知识点:一、响应式编程核心概念1.1什么是响应式编程?响应式编程是一种声明式编程范式,它使数据变化能够自动传播到依赖它的代码部分。在Vue中,响应式系统实现了:数据驱动视图:数据变化自动更新DOM依赖追踪:自动跟踪数据依赖关系高效更新:最小化不必要的DOM操作1.2Vue响应式系统演进版本响应式实现特点Vue2Object.defin
- vue3 实现文件上传
编程(变成)小辣鸡
vuevue
1、上传文件html上传文件 将文件拖到此处,或点击上传只支持pdf、doc、docx、png、jpg提交import{ref,reactive}from'vue'import{uploadImg}from'@/api/common.js';letuploadFile=ref(false);letfileList=ref([]);constupload=(val)=>{fileLis
- 使用openpyxl的append写入excel出现AttributeError的可能原因
2301_79717431
excel
之前源码是这样的,importopenpyxlfromopenpyxlimportWorkbookwb=openpyxl.load_workbook('text.xlsx')sheet=wb.activec=[1,2,"a",4]sheet.append(c)sheet.save('text.xlsx')最后一句有问题,save需要保存的时wb这个文件,而不是sheet表格!
- vue3教程笔记
Xaire
javascriptvue.js前端
选项式的写法基本和vue2一致。组合式写法:reactive()只适用于对象(数组或者内置对象),创建的对象都是js的proxy。import{reactive}from'vue'constcounter=reactive({count:0})console.log(counter.count)//0counter.count++ref()则可以接受任何值类型,ref会返回一个包裹对象,并在.va
- Vue 3 组合式API深度剖析:工具函数详解
aike13ky
vue.jsjavascript
目录前言一、工具函数介绍1.isRef()2.unref()3.toRef()4.toValue()5.toRefs()6.isProxy()7.isReactive()8.isReadonly()前言组合式API除了为我们提供一些核心API,还为我们提供了很多工具函数。核心API详解请移步另一篇博客--->Vue3组合式API深度剖析:核心API使用指南在Vue3中,组合式API为我们提供了一种
- systemctl命令列出所有服务
willops
Linuxlinux
systemctl命令列出所有服务systemctl是Systemd的主命令,可用于管理系统。列出所有已经加载的systemdunitssystemctlsystemctl|grepdocker.service列出所有servicesystemctllist-units--type=servicesystemctl--type=service列出所有active状态(运行或退出)的服务system
- vue3递归组件的使用
未央区邓紫棋
vue.jsvue.js前端javascript
HelloWorld.vue{{item}}import{ref,reactive}from'vue'importHelloWorldTtemfrom'./HelloWorld.vue'typeTreeList={name:string;icon?:string;children?:TreeList[]|[];};typeProps={data?:T[]|[]}defineProps>()app.
- el-dropdown自定义“更多操作⌵”上下文关联按钮)下拉菜单
你挚爱的强哥
Sg.js框架vue.jsjavascript前端
{//dropdownActive=command;letindex=dropdownItems.findIndex((v)=>v.label==command);letitem=dropdownItems[index];item.clickEvent&&item.clickEvent({item,index,scope:scope});}">更多-->{{d.label}}exportdefau
- 3DSwiper 好看的走马灯轮播图
代码来源vue3写法,复制即用❮❯//配置参数constconfig=reactive({maxWidth:'180px',speed:10000,//轮播速度multiple:1,//鼠标悬停放大倍速autoPlay:true,//是否自动轮播imgList:["https://img0.baidu.com/it/u=1446729335,4267600834&fm=
- Vue3父子组件通信
一只路人甲
前端vue.jsjavascript前端
一,父传子:props单向数据流原则禁止子组件直接修改prop通过自定义事件通知父组件更新App.vue我是父组件更新父组件数据,传递到子组件了import{ref,reactive}from'vue'importCompfrom'./Comp.vue'constparentMessage=ref('初始消息')constuser=reactive({name:'andy',age:13})con
- 磁悬浮轴承温度漂移克星:三招实现精准控制
FanXing_zl
磁悬浮轴承磁悬浮磁悬浮轴承控制磁悬浮轴承磁悬浮智能硬件传感器温漂
在磁悬浮轴承(ActiveMagneticBearing,AMB)的高性能应用中,位置传感器的精度就是系统的生命线。然而,传感器输出随温度变化产生的漂移(温漂),如同一个潜伏的破坏者,悄然引入测量误差,轻则导致转子振动加剧、功耗上升,重则引发稳定性崩溃、转子跌落。本文将深入剖析温漂成因,并从传感器选型、结构安装、控制算法三个维度,提供系统的解决方案。一、精准选型:从源头扼制温漂传感器是温漂的源头,
- 磁悬浮轴承电磁设计:从理论到实践的高性能跃迁之路
FanXing_zl
磁悬浮轴承磁悬浮磁悬浮轴承磁悬浮电磁设计磁悬浮控制性能对比
某高速透平机械项目现场,工程师们屏息凝神。随着指令下达,转子在完全无接触的磁力支撑下平稳越过120kRPM临界转速,振动值稳定在2μm以内—这场静默的悬浮之舞,其核心秘密正隐藏在精妙的电磁设计之中。一、磁悬浮轴承:电磁力支撑的工业革新磁悬浮轴承(ActiveMagneticBearing,AMB)通过可控电磁力实现转子稳定无接触悬浮,彻底消除了机械摩擦与润滑需求。其核心优势在于:支持超高转速:支持
- CSS 问题记录::active 状态下背景超出 border-radius 的圆角区域
码客前端
css前端
CSS问题记录::active状态下背景超出border-radius的圆角区域问题描述在开发中,我们经常使用:active伪类来为可点击元素添加激活状态的样式。但在某些情况下,当元素设置了cursor:pointer并触发:active状态时,背景颜色会填充整个矩形区域,而忽略了原本设置的border-radius圆角效果。这会导致视觉上不符合预期,尤其是在按钮或菜单项等需要圆角设计的UI元素中
- Spring WebFlux 功能介绍,使用场景,完整使用示例
慧一居士
JAVAjava
SpringWebFlux是SpringFramework5+引入的非阻塞、响应式Web框架,旨在充分利用现代多核处理器和异步I/O模型(如Netty、Undertow、Servlet3.1+容器),处理海量并发连接,特别适合低延迟、高吞吐量的应用场景。它是SpringMVC的补充,为响应式编程模型提供了完整的支持。核心功能:非阻塞&响应式核心:基于ProjectReactor(ReactiveS
- Vue开发的商城系统
速易达网络
移动应用开发课程vue.js
下面我将为您设计一个基于Vue的完整商城系统,包含商品展示、购物车等功能。系统设计思路前端架构:Vue+VueRouter核心功能模块:用户认证(登录/注册)商品浏览与搜索购物车管理订单创建与支付个人中心完整实现代码Vue商城☰<nav:class="{active:menuActive}"
- 使用vue3+el-form实现动态新增名称,值,并对名称进行必填校验
从不讲道理
vuevue.js前端javascript
使用vue3+el-form实现动态新增名称,值,并对名称进行必填校验效果图代码+-AddItem-->Submit-->import{ref,reactive,defineProps,watch}from'vue'constprops=defineProps({defaultData:{type:[Object,Array]},disabled:{type:Boolean,default:fal
- Tool 类 API 文档:灵活的数据状态管理工具
程序猿全栈の董
学习开源c++后端
Tool类API文档:灵活的数据状态管理工具概述Tool是一个轻量级的C++类,专为需要跟踪和管理数据状态的场景设计。它提供了一种简洁的方式来更新值并同时获取之前的值,使开发者能够轻松实现状态变更、值交换和历史记录等功能。类定义classTool{intdata;public:Tool();Tool(intinitialValue);~Tool();intinteractive(intmyVar)
- Vue3 响应式原理
旺代
vue.jsjavascript前端
目录一、Proxy代理1.Proxy工作原理2.依赖收集系统3.ref的实现原理4.reactive的实现原理5.副作用系统(Effect)6.响应式系统的优势7.响应式流程总结二、组件触发渲染的时机1.首次挂载时2.响应式数据变更3.Props更新4.强制更新三、Vue3组件生命周期流程一、创建阶段(组件实例初始化)二、挂载阶段(DOM插入页面)三、更新阶段(响应数据变化)四、销毁阶段(移除组件
- Ubuntu20.04安装ssh并开启远程访问登录
未既
linux专栏ssh服务器linux
1.安装openssh-server打开终端安装openssh-server软件包:sudoaptupdate#更新包sudoaptinstallopenssh-server#安装openssh-server2.查看ssh状态安装完成后,ssh服务默认启动了,可以通过下面的命令检查服务运行状态:sudosystemctlstatusssh如果出现以下的内容,注意“active”是“running”
- Spring Boot + MyBatis Plus + SpringAI + Vue 毕设项目开发全解析(源码)
前言前些天发现了一个巨牛的人工智能免费学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站SpringBoot+MyBatisPlus+SpringAI+Vue毕设项目开发全解析目录一、项目概述与技术选型项目背景与需求分析技术栈选择对比(SpringBootvs其他框架)核心技术说明SpringBoot3.x快速开发特性MyBatisPlus代码生成器与ActiveRecord模式S
- 腾讯云主动型云蜜罐技术解析:云原生威胁狩猎的革新实践(基于腾讯云开发者社区技术网页与行业实践)
小猴崽
主动型云蜜罐蜜罐云蜜罐
摘要腾讯云主动型云蜜罐(ActiveCloudHoneypot)通过动态诱捕机制和云原生架构,在威胁检测效率、攻击链还原深度、防御联动实时性等维度实现突破。相较于传统蜜罐,其核心优势体现在:部署效率:分钟级完成多云环境部署,较物理蜜罐方案提速300%数据价值密度:单节点日均捕获攻击特征数达2,300+条(行业平均580条)安全合规性:通过等保2.0三级认证,满足金融、能源等行业监管要求一、核心技术
- vscode打开多个项目的时候,设置“任务栏处以项目名称”显示
ZONGYINLIU
环境安装部署vscode
在VSCode中打开多个项目时,任务栏默认显示单个文件名。我们可将其调整为显示项目名称而不是单个文件名,以便更容易区分不同的项目在设置中搜“Window:Title”改成:${dirty}${rootName}${separator}${activeEditorMedium}${separator}${appName}效果如下:
- css实现角标效果并带有文章或图标
默默地写代码
csscss3前端
代码示例:.coupon_card.active{border:1pxsolid#f32121;position:relative;}.coupon_card.active::after{content:'';position:absolute;right:0;bottom:0;border-width:0020px20px;border-style:solid;border-color:tran
- 防火墙的禁用及开启
qq_33928223
安全管理网络知识系统管理网络服务器运维
要禁用firewalld的开机自启动,可以通过以下步骤操作:1.检查firewalld状态首先,确认firewalld是否正在运行:sudosystemctlstatusfirewalld如果显示active(running),说明firewalld正在运行。2.停止firewalld服务如果firewalld正在运行,可以先停止它:sudosystemctlstopfirewalld3.禁用fi
- oracle ash说明,ASH报告解读
跨考考研
oracleash说明
TopEventsTopUserEventsEventEventClass%ActivityAvgActiveSessionsCPU+WaitforCPUCPU69.832.75cursor:pinSwaitonXConcurrency22.500.89dbfilesequentialreadUserI/O3.360.13这一部分是用户会话的等待事件的信息。列出了采样时段内数据库发生的显著用户等待
- 46-Oracle ASH-报告生成
小伙伴们,OracleASH(ActiveSessionHistory)日常排查性能问题的多不多。当业务突然卡顿、告警频发时,ASH快速定位问题(每秒采样活动会话的等待事件、SQL_ID和阻塞关系,直接透视数据库的实时状态),这个用起来还是很顺手的。ASH是DBA的灭火器,尤其在秒级故障定位中无可替代。不过由于数据保存时间有时效数据容易被覆盖哦。一、OracleASH性能监控来历和价值传统监控局限
- 47-Oracle ASH报告解读
上一期生成了ASH报告后,就需要解读报告关键信息。ASH的使用可以快速定位瞬时性能问题。生产环境的场景时间紧、任务重,但是必须要结合具体业务分析,同时借助其他工具做报告做趋势分析。一、ASH技术原理1.核心机制采样原理:ASH每秒采样一次活动会话(状态为ACTIVE,非空闲等待),由后台进程MMNL(MemoryMonitorLight)执行数据存储:内存:采样数据存储在SGA的循环缓冲区(V$A
- 局域网内powerjob分布式调度server端启动docker命令
星梦客
powerjobdocker容器
dockerrun-d\--restart=always\--net=host\--namepowerjob-server\-eTZ="Asia/Shanghai"\-eJVMOPTIONS="-Dpowerjob.network.interface.preferred=ztw4lfbxtd"\-ePARAMS="--spring.profiles.active=product--spring.d
- 继之前的线程循环加到窗口中运行
3213213333332132
javathreadJFrameJPanel
之前写了有关java线程的循环执行和结束,因为想制作成exe文件,想把执行的效果加到窗口上,所以就结合了JFrame和JPanel写了这个程序,这里直接贴出代码,在窗口上运行的效果下面有附图。
package thread;
import java.awt.Graphics;
import java.text.SimpleDateFormat;
import java.util
- linux 常用命令
BlueSkator
linux命令
1.grep
相信这个命令可以说是大家最常用的命令之一了。尤其是查询生产环境的日志,这个命令绝对是必不可少的。
但之前总是习惯于使用 (grep -n 关键字 文件名 )查出关键字以及该关键字所在的行数,然后再用 (sed -n '100,200p' 文件名),去查出该关键字之后的日志内容。
但其实还有更简便的办法,就是用(grep -B n、-A n、-C n 关键
- php heredoc原文档和nowdoc语法
dcj3sjt126com
PHPheredocnowdoc
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Current To-Do List</title>
</head>
<body>
<?
- overflow的属性
周华华
JavaScript
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml&q
- 《我所了解的Java》——总体目录
g21121
java
准备用一年左右时间写一个系列的文章《我所了解的Java》,目录及内容会不断完善及调整。
在编写相关内容时难免出现笔误、代码无法执行、名词理解错误等,请大家及时指出,我会第一时间更正。
&n
- [简单]docx4j常用方法小结
53873039oycg
docx
本代码基于docx4j-3.2.0,在office word 2007上测试通过。代码如下:
import java.io.File;
import java.io.FileInputStream;
import ja
- Spring配置学习
云端月影
spring配置
首先来看一个标准的Spring配置文件 applicationContext.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi=&q
- Java新手入门的30个基本概念三
aijuans
java新手java 入门
17.Java中的每一个类都是从Object类扩展而来的。 18.object类中的equal和toString方法。 equal用于测试一个对象是否同另一个对象相等。 toString返回一个代表该对象的字符串,几乎每一个类都会重载该方法,以便返回当前状态的正确表示.(toString 方法是一个很重要的方法) 19.通用编程:任何类类型的所有值都可以同object类性的变量来代替。
- 《2008 IBM Rational 软件开发高峰论坛会议》小记
antonyup_2006
软件测试敏捷开发项目管理IBM活动
我一直想写些总结,用于交流和备忘,然都没提笔,今以一篇参加活动的感受小记开个头,呵呵!
其实参加《2008 IBM Rational 软件开发高峰论坛会议》是9月4号,那天刚好调休.但接着项目颇为忙,所以今天在中秋佳节的假期里整理了下.
参加这次活动是一个朋友给的一个邀请书,才知道有这样的一个活动,虽然现在项目暂时没用到IBM的解决方案,但觉的参与这样一个活动可以拓宽下视野和相关知识.
- PL/SQL的过程编程,异常,声明变量,PL/SQL块
百合不是茶
PL/SQL的过程编程异常PL/SQL块声明变量
PL/SQL;
过程;
符号;
变量;
PL/SQL块;
输出;
异常;
PL/SQL 是过程语言(Procedural Language)与结构化查询语言(SQL)结合而成的编程语言PL/SQL 是对 SQL 的扩展,sql的执行时每次都要写操作
- Mockito(三)--完整功能介绍
bijian1013
持续集成mockito单元测试
mockito官网:http://code.google.com/p/mockito/,打开documentation可以看到官方最新的文档资料。
一.使用mockito验证行为
//首先要import Mockito
import static org.mockito.Mockito.*;
//mo
- 精通Oracle10编程SQL(8)使用复合数据类型
bijian1013
oracle数据库plsql
/*
*使用复合数据类型
*/
--PL/SQL记录
--定义PL/SQL记录
--自定义PL/SQL记录
DECLARE
TYPE emp_record_type IS RECORD(
name emp.ename%TYPE,
salary emp.sal%TYPE,
dno emp.deptno%TYPE
);
emp_
- 【Linux常用命令一】grep命令
bit1129
Linux常用命令
grep命令格式
grep [option] pattern [file-list]
grep命令用于在指定的文件(一个或者多个,file-list)中查找包含模式串(pattern)的行,[option]用于控制grep命令的查找方式。
pattern可以是普通字符串,也可以是正则表达式,当查找的字符串包含正则表达式字符或者特
- mybatis3入门学习笔记
白糖_
sqlibatisqqjdbc配置管理
MyBatis 的前身就是iBatis,是一个数据持久层(ORM)框架。 MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架。MyBatis对JDBC进行了一次很浅的封装。
以前也学过iBatis,因为MyBatis是iBatis的升级版本,最初以为改动应该不大,实际结果是MyBatis对配置文件进行了一些大的改动,使整个框架更加方便人性化。
- Linux 命令神器:lsof 入门
ronin47
lsof
lsof是系统管理/安全的尤伯工具。我大多数时候用它来从系统获得与网络连接相关的信息,但那只是这个强大而又鲜为人知的应用的第一步。将这个工具称之为lsof真实名副其实,因为它是指“列出打开文件(lists openfiles)”。而有一点要切记,在Unix中一切(包括网络套接口)都是文件。
有趣的是,lsof也是有着最多
- java实现两个大数相加,可能存在溢出。
bylijinnan
java实现
import java.math.BigInteger;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class BigIntegerAddition {
/**
* 题目:java实现两个大数相加,可能存在溢出。
* 如123456789 + 987654321
- Kettle学习资料分享,附大神用Kettle的一套流程完成对整个数据库迁移方法
Kai_Ge
Kettle
Kettle学习资料分享
Kettle 3.2 使用说明书
目录
概述..........................................................................................................................................7
1.Kettle 资源库管
- [货币与金融]钢之炼金术士
comsci
金融
自古以来,都有一些人在从事炼金术的工作.........但是很少有成功的
那么随着人类在理论物理和工程物理上面取得的一些突破性进展......
炼金术这个古老
- Toast原来也可以多样化
dai_lm
androidtoast
Style 1: 默认
Toast def = Toast.makeText(this, "default", Toast.LENGTH_SHORT);
def.show();
Style 2: 顶部显示
Toast top = Toast.makeText(this, "top", Toast.LENGTH_SHORT);
t
- java数据计算的几种解决方法3
datamachine
javahadoopibatisr-languer
4、iBatis
简单敏捷因此强大的数据计算层。和Hibernate不同,它鼓励写SQL,所以学习成本最低。同时它用最小的代价实现了计算脚本和JAVA代码的解耦,只用20%的代价就实现了hibernate 80%的功能,没实现的20%是计算脚本和数据库的解耦。
复杂计算环境是它的弱项,比如:分布式计算、复杂计算、非数据
- 向网页中插入透明Flash的方法和技巧
dcj3sjt126com
htmlWebFlash
将
Flash 作品插入网页的时候,我们有时候会需要将它设为透明,有时候我们需要在Flash的背面插入一些漂亮的图片,搭配出漂亮的效果……下面我们介绍一些将Flash插入网页中的一些透明的设置技巧。
一、Swf透明、无坐标控制 首先教大家最简单的插入Flash的代码,透明,无坐标控制: 注意wmode="transparent"是控制Flash是否透明
- ios UICollectionView的使用
dcj3sjt126com
UICollectionView的使用有两种方法,一种是继承UICollectionViewController,这个Controller会自带一个UICollectionView;另外一种是作为一个视图放在普通的UIViewController里面。
个人更喜欢第二种。下面采用第二种方式简单介绍一下UICollectionView的使用。
1.UIViewController实现委托,代码如
- Eos平台java公共逻辑
蕃薯耀
Eos平台java公共逻辑Eos平台java公共逻辑
Eos平台java公共逻辑
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
蕃薯耀 2015年6月1日 17:20:4
- SpringMVC4零配置--Web上下文配置【MvcConfig】
hanqunfeng
springmvc4
与SpringSecurity的配置类似,spring同样为我们提供了一个实现类WebMvcConfigurationSupport和一个注解@EnableWebMvc以帮助我们减少bean的声明。
applicationContext-MvcConfig.xml
<!-- 启用注解,并定义组件查找规则 ,mvc层只负责扫描@Controller -->
<
- 解决ie和其他浏览器poi下载excel文件名乱码
jackyrong
Excel
使用poi,做传统的excel导出,然后想在浏览器中,让用户选择另存为,保存用户下载的xls文件,这个时候,可能的是在ie下出现乱码(ie,9,10,11),但在firefox,chrome下没乱码,
因此必须综合判断,编写一个工具类:
/**
*
* @Title: pro
- 挥洒泪水的青春
lampcy
编程生活程序员
2015年2月28日,我辞职了,离开了相处一年的触控,转过身--挥洒掉泪水,毅然来到了兄弟连,背负着许多的不解、质疑——”你一个零基础、脑子又不聪明的人,还敢跨行业,选择Unity3D?“,”真是不自量力••••••“,”真是初生牛犊不怕虎•••••“,••••••我只是淡淡一笑,拎着行李----坐上了通向挥洒泪水的青春之地——兄弟连!
这就是我青春的分割线,不后悔,只会去用泪水浇灌——已经来到
- 稳增长之中国股市两点意见-----严控做空,建立涨跌停版停牌重组机制
nannan408
对于股市,我们国家的监管还是有点拼的,但始终拼不过飞流直下的恐慌,为什么呢?
笔者首先支持股市的监管。对于股市越管越荡的现象,笔者认为首先是做空力量超过了股市自身的升力,并且对于跌停停牌重组的快速反应还没建立好,上市公司对于股价下跌没有很好的利好支撑。
我们来看美国和香港是怎么应对股灾的。美国是靠禁止重要股票做空,在
- 动态设置iframe高度(iframe高度自适应)
Rainbow702
JavaScriptiframecontentDocument高度自适应局部刷新
如果需要对画面中的部分区域作局部刷新,大家可能都会想到使用ajax。
但有些情况下,须使用在页面中嵌入一个iframe来作局部刷新。
对于使用iframe的情况,发现有一个问题,就是iframe中的页面的高度可能会很高,但是外面页面并不会被iframe内部页面给撑开,如下面的结构:
<div id="content">
<div id=&quo
- 用Rapael做图表
tntxia
rap
function drawReport(paper,attr,data){
var width = attr.width;
var height = attr.height;
var max = 0;
&nbs
- HTML5 bootstrap2网页兼容(支持IE10以下)
xiaoluode
html5bootstrap
<!DOCTYPE html>
<html>
<head lang="zh-CN">
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">