- 【spring-kafka】@KafkaListener详解与使用
2401_84408092
程序员springkafkalinq
id监听器的id①.消费者线程命名规则填写:2020-11-1914:24:15c.d.b.k.KafkaListeners120[INFO]线程:Thread[consumer-id5-1-C-1,5,main]-groupId:BASE-DEMOconsumer-id5消费没有填写ID:2020-11-1910:41:26c.d.b.k.KafkaListeners137[INFO]线程:Th
- MySQL分组排序去重多表联查_MySQL基础(二):多表查询 -- 分组排序
love彤彤
MySQL分组排序去重多表联查
多表查询:连接查询-子查询MySQL基础操作链接;工具:SQLyogMySQL语法顺序:select[distinct]fromjoin(leftjoin/rightjoin)onwheregroupbyhavingunionorderbylimit1.表结构用户,角色,权限三张表(主表)及三者之间的关系通过两张“第三张外键表”维护。“外键表”中的两个字段分别使用外键指向主表的主键。(一个用户可以
- 【mysql】如何解决主从架构从库延迟问题
王佑辉
mysqlmysql
目录1.说明2.优化主库的写入性能3.优化网络性能4.增强从库的硬件性能5.调整从库的配置6.主从架构优化7.监控和调优8.使用GTID和GroupReplication1.说明1.在MySQL数据库中,从库延迟(replicationlag)是指主库和从库之间的数据不同步现象,通常是由于从库无法跟上主库的写操作速度导致的。2.优化主库的写入性能1.减少主库的写入负载可以间接缓解从库的延迟问题。2
- 在 JMeter 中实现多用户并发登录及操作
噔噔噔噔@
jmeter
在JMeter中实现多用户并发登录及操作,通常需要以下步骤:1.创建测试计划打开JMeter。右键点击“TestPlan”,选择“Add>Threads(Users)>ThreadGroup”。:设置并发用户数。:设置用户启动的时间间隔。:设置循环次数,或选择“Infinite”进行持续测试。2.添加HTTP请求右键点击“ThreadGroup”,选择“Add>Sampler>HTTPReques
- 【Pandas】DataFrame操作函数
Jonina Beyang
Pandaspandas
目录1.批量处理函数-apply()参数funcaxisrawresult_typeargsby_row应用(1).LeetCode-1873.计算特殊奖金2.分组函数groupby()参数by/axis/level/as_indexaxisas_index应用(1).LeetCode-184.部门工资最高的员工(2).LeetCode-1741.查找每个员工花费的总时间3.透视函数melt()参
- Vulkan:Vulkan物理模拟与碰撞检测技术教程_2024-07-20_15-47-39.Tex
chenjj4003
游戏开发microsoft网络服务器linux前端数据结构
Vulkan:Vulkan物理模拟与碰撞检测技术教程Vulkan基础与环境搭建Vulkan库的简介与特性Vulkan是一个跨平台的2D和3D图形与计算API。它由KhronosGroup开发,旨在提供高性能的图形渲染和计算能力,同时减少CPU的开销,提高GPU的利用率。Vulkan的特性包括:低级API:Vulkan提供了对硬件的直接访问,允许开发者精细控制GPU资源,从而实现更高的性能和效率。多
- Vulkan:Vulkan基础架构与环境搭建_2024-07-20_13-37-15.Tex
chenjj4003
游戏开发网络服务器linux前端数据结构androidjava
Vulkan:Vulkan基础架构与环境搭建Vulkan简介Vulkan的历史与发展Vulkan是一个跨平台的2D和3D图形及计算API,由KhronosGroup开发。KhronosGroup是一个由多家公司组成的非营利性行业联盟,负责制定和维护多种开放标准,包括Vulkan、OpenGL、OpenCL等。Vulkan的设计目标是提供更高效、更直接的硬件访问,以减少CPU在图形渲染中的开销,同时
- INX246 HTML CSS PHP
后端
GroupProject2/2024INX246ADVANCEDCOMPUTERPROGRAMMINGFORMODERNMANAGEMENTProjectOverviewGroupproject:3-4memberspergroupDevelopawebsitewithdatabaseandagroupreportProjectsubmissionandpresentation(on-sit
- SQL中如何使用GROUP BY语句
用完记得换回去
sql数据库
GROUPBY语句在SQL中用于:将行数据根据列进行分组。当你想要对数据进行分组并对每个分组进行聚合计算(如计数、求和、平均等)时,GROUPBY非常有用。以下是基本步骤和示例:基本语法SELECTcolumn_name(s),AGGREGATE_FUNCTION(column_name)FROMtable_nameWHEREconditionGROUPBYcolumn_name(s)ORDERB
- 代 写Name Database Systems
后端
AssessedCourseworkCourseNameDatabaseSystems(H)CourseworkNumber1/1DeadlineTime:16h30Date:14/03/2025%Contributiontofinalcoursemark20%SoloorGroup✓SoloGroup✓AnticipatedHoursAverage20hoursSubmissionInstruc
- linux命令.pdf,linux命令大全完整版.pdf
gjbgyuhg
linux命令.pdf
linux命令大全完整版Linux命令大全完整版目录目录I1.linux系统管理命令1adduser1chfn(changefingerinformation)1chsh(changeshell)1date2exit3finger4free5fwhois5gitps(gnuinteractivetoolsprocessstatus)5groupdel(groupdelete)6groupmod(g
- maven引包爆红 failed to transfer from http://maven.aliyun.com/nexus/content/groups/public during a previ
sui5yue6_
mavenjava
之前一致可以正常使用,然后突然无法引入新的包无法引包org.apache.flink:flink-streaming-java_2.12:pom:1.13.1failedtotransferfromhttp://maven.aliyun.com/nexus/content/groups/publicduringapreviousattempt.Thisfailurewascachedinthelo
- Touch事件分发机制
Ti_wj
Touch事件分发中只有两个主角:ViewGroup和View。Activity的Touch事件事实上是调用它内部的ViewGroup的Touch事件,可以直接当成ViewGroup处理。View在ViewGroup内,ViewGroup也可以在其他ViewGroup内,这时候把内部的ViewGroup当成View来分析。ViewGroup的相关事件有三个:onInterceptTouchEven
- Go爬虫学习笔记_go爬虫的知识储备
2401_86372470
golang爬虫学习
接口空接口定义、声明实现调用组合断言动态类型v.(type)比较并发协程通道声明、初始化读写关闭作为参数作为返回值单方向的通道,用于只读和只写场景select,随机执行context协程优雅退出级联退出原子锁:atomic互斥锁读写锁:适合多读少写场景。sync.Once、sync.Cond、sync.WaitGroup项目组织依赖管理:gomod组合工具与库编辑测试:编译部署:调试分析工具:代码
- web前端--html 5---qq注册
粉0321
web前端前端html
qq注册.theme{width:300px;height:600px;margin:0pxauto;}.theme1select{padding:5px10px;border:none;border-color:#B8B8B8;box-sizing:border-box;font-size:14px;color:#B8B8B8;}.a1{color:#4b7cde;}.form-group1in
- 容器——Cgroup简介
爱吃芝麻汤圆
#容器Linuxlinux容器docker
文章目录Cgroup简介Cgroup核心概念Cgroup(ControlGroup)定义核心功能特点Cgroup树(Hierarchy)定义特点作用Subsystem(子系统)定义常见子系统特点查看子系统挂载(Mount)定义特点示例作用Cgroup文件定义常见文件作用Cgroup核心交互逻辑hierarchy(层级结构)与subsystem(子系统)的关系hierarchy与进程(task)的关
- mysql为啥使用B+树
讨吃的讨吃了
mysqlb树数据库
MySQL的InnoDB存储引擎采用B+树作为索引结构(而不是B树或其他数据结构),主要是基于B+树在数据库场景下的独特优势。以下是MySQL采用B+树的具体原因:1.B+树的核心优势(1)更适合范围查询B+树的叶子节点通过指针连接成一个有序链表,这非常适合范围查询(如BETWEEN、ORDERBY或GROUPBY)。在数据库中,范围查询是非常常见的操作,而B+树能够高效地支持这种查询模式。(2)
- 单独使用 HAVING 的条件
零点溯灵
数据库
在SQL中,HAVING子句通常与GROUPBY一起使用,用于对分组后的结果进行过滤。但即使没有GROUPBY,HAVING也可以单独使用,需满足以下条件:单独使用HAVING的条件查询中包含聚合函数(如SUM,COUNT,AVG,MAX,MIN等)HAVING的过滤条件必须基于聚合函数的结果,此时整个查询结果会被隐式视为一个“单一分组”。没有GROUPBY子句此时所有行会被视为一个整体分组,HA
- IntelliJ IDEA配置 tomcat
太阳上的雨天
JAVAjavaidea
创建测试项目HttpServletDemo打开IDEA新建一个maven项目,按图中选择之后,点击下一步填写项目名字,位置,Groupid,点击下一步配置Maven的相关目录配置tomcat
- mysql 视图 union all_关于用mysql创建视图以及union all 和group by相关介绍
ZackRen
mysql视图unionall
一.关于视图1.视图的含义:视图就是一个存在于数据库中的虚拟表。视图本身没有数据,只是通过执行相应的select语句完成获得相应的数据。2.不可更新的视图:某些视图是可更新的。也就是说,可以在诸如UPDATE、DELETE或INSERT等语句中使用它们,以更新基表的内容。对于可更新的视图,在视图中的行和基表中的行之间必须具有一对一的关系。还有一些特定的其他结构,这类结构会使得视图不可更新。更具体地
- sqlserver mysql Cube_SQLServer中的GROUPING,ROLLUP和CUBE
weixin_39546501
sqlservermysqlCube
聚集函数:GROUPING用于汇总数据用的运算符:ROLLUP1.用CUBE汇总数据CUBE运算符生成的结果集是多维数据集。多维数据集是事实数据的扩展,事实数据即记录个别事件的数据。扩展建立在用户打算分析的列上。这些列被称为维。多维数据集是一个结果集,其中包聚集函数:GROUPING用于汇总数据用的运算符:ROLLUP1.用CUBE汇总数据CUBE运算符生成的结果集是多维数据集。多维数据集是事实数
- ClickHouse SQL 查询中别名导致报错的问题分析与解决方案
水涵幽树
clickhousesql数据库后端学习数据库开发
一、引言在使用ClickHouse数据库进行数据查询时,SQL语句中的别名使用是常见的优化手段之一。但是,不当的别名使用可能会引发解析错误,影响查询结果的正确性。下面将通过实例详细探讨因别名使用而导致报错的原因,并提供相应的解决方案。二、问题描述考虑以下SQL查询片段:SELECTa.event_type2_idasevent_type2,...FROMtable_aaGROUPBYa.event
- C++MFC常用控件
刘欢(C#)
C++c++mfc
_按钮(Button)_编辑框(EditControl)_标签(StaticText)_超级列表框(ListControl)_分组框(GroupBox)_复选框(CheckBox)_树形框(TreeControl)_图片框(PictureControl)_文件选择框(MFCEditBrowseControl)_选择夹(TabControl)_组合框(ComboBox)_avi短动画命令按钮(Com
- 图解MySQL【日志】——磁盘 I/O 次数过高时优化的办法
松弛进取
mysql数据库java后端性能优化
MySQL磁盘I/O次数过高时优化的办法事务提交时,需要将RedoLog和Binlog持久化到磁盘中,可以通过四个参数,来控制刷盘时机,以降低磁盘I/O的频率。组提交的两个参数binlog_group_commit_sync_delay:控制事务提交前的最大等待时间。binlog_group_commit_sync_no_delay_count:控制组提交的事务数量,达到该值时,不用等待延迟时间,
- MySQL中,对结果或条件进行字符串拼接
不会拆家的二哈
数据库mysql数据库sql
在MySQL中,实现字符串拼接主要有以下3种函数:concat(x,y,…)concat_ws(分隔符,x,y,…)group_concat(distinctxxxorderbyasd/descyyyseparator‘分隔符’)一、concat函数concat()函数用于将多个字符串连接成一个字符串格式:concat(str1,str2,…)–mysqlconcat()–SELECTCONCAT
- 【可靠有效】springboot使用netty搭建TCP服务器
weixin_43833540
springbootnettytcp
NettyNetty是一个高性能、异步事件驱动的网络应用程序框架,它提供了对并发和异步编程的抽象,使得开发网络应用程序变得更加简单和高效。在Netty中,EventLoopGroup是处理I/O操作的多线程事件循环器。在上面的示例中,我们创建了两个EventLoopGroup实例:bossGroup和workerGroup。bossGroup负责接收客户端的连接请求,并将这些连接分配给worker
- JMeter 中实现 100 个用户在 3 秒内并发登录
噔噔噔噔@
软件测试基础及工具分享jmeter
在JMeter中实现100个用户在3秒内并发登录,需要合理配置线程组、定时器和测试逻辑。以下是具体步骤:1.创建测试计划打开JMeter。右键点击“TestPlan”,选择Add>Threads(Users)>ThreadGroup。:设置为100(模拟100个用户)。:设置为3
- The target table my_view3 of the UPDATE is not updatable 怎么解决?
cccccchd
mysqlsql
检查视图是否基于单个表。如果没有,请考虑改为更新基础表。检查视图是否具有任何聚合,例如GROUPBY子句,并在可能的情况下将其删除。检查视图的定义中是否有任何子查询,并在可能的情况下简化或重写它们。检查视图是否包含任何计算列,例如使用表达式或函数创建的列,并考虑删除它们。请考虑在视图上创建一个INSTEADOF触发器来处理更新。确保您具有更新视图所需的权限。请务必注意,并非所有视图都是可更新的,尤
- 达梦数据库并发场景下,抓取执行久/等待久的慢SQL
泛冬以南
常用技术记录数据库sql
--ss单位是秒select*from(select(SELECTround(SUM(TOTAL_SIZE/1024/1024),2)FROMV$MEM_POOLCwhereC.name='VIRTUALMACHINE'ANDC.CREATOR=A.THRD_IDGROUPBYCREATOR)ASVM_TOTAL_SIZE_BY_M,a.trx_id,a.thrd_id,clnt_ip,c.ROL
- SQL FIRST() 函数详解
lsx202406
开发语言
SQLFIRST()函数详解在SQL中,FIRST()函数是一个用于处理查询结果的聚合函数。它通常与GROUPBY子句结合使用,用于返回每个分组中的第一个记录。本文将详细解释FIRST()函数的用法、参数、返回值以及与它的关联函数。1.函数概述FIRST()函数的基本语法如下:SELECTFIRST(column_name)FROMtable_nameWHEREcondition;在这个语法中,c
- ASM系列四 利用Method 组件动态注入方法逻辑
lijingyao8206
字节码技术jvmAOP动态代理ASM
这篇继续结合例子来深入了解下Method组件动态变更方法字节码的实现。通过前面一篇,知道ClassVisitor 的visitMethod()方法可以返回一个MethodVisitor的实例。那么我们也基本可以知道,同ClassVisitor改变类成员一样,MethodVIsistor如果需要改变方法成员,注入逻辑,也可以
- java编程思想 --内部类
百合不是茶
java内部类匿名内部类
内部类;了解外部类 并能与之通信 内部类写出来的代码更加整洁与优雅
1,内部类的创建 内部类是创建在类中的
package com.wj.InsideClass;
/*
* 内部类的创建
*/
public class CreateInsideClass {
public CreateInsideClass(
- web.xml报错
crabdave
web.xml
web.xml报错
The content of element type "web-app" must match "(icon?,display-
name?,description?,distributable?,context-param*,filter*,filter-mapping*,listener*,servlet*,s
- 泛型类的自定义
麦田的设计者
javaandroid泛型
为什么要定义泛型类,当类中要操作的引用数据类型不确定的时候。
采用泛型类,完成扩展。
例如有一个学生类
Student{
Student(){
System.out.println("I'm a student.....");
}
}
有一个老师类
- CSS清除浮动的4中方法
IT独行者
JavaScriptUIcss
清除浮动这个问题,做前端的应该再熟悉不过了,咱是个新人,所以还是记个笔记,做个积累,努力学习向大神靠近。CSS清除浮动的方法网上一搜,大概有N多种,用过几种,说下个人感受。
1、结尾处加空div标签 clear:both 1 2 3 4
.div
1
{
background
:
#000080
;
border
:
1px
s
- Cygwin使用windows的jdk 配置方法
_wy_
jdkwindowscygwin
1.[vim /etc/profile]
JAVA_HOME="/cgydrive/d/Java/jdk1.6.0_43" (windows下jdk路径为D:\Java\jdk1.6.0_43)
PATH="$JAVA_HOME/bin:${PATH}"
CLAS
- linux下安装maven
无量
mavenlinux安装
Linux下安装maven(转) 1.首先到Maven官网
下载安装文件,目前最新版本为3.0.3,下载文件为
apache-maven-3.0.3-bin.tar.gz,下载可以使用wget命令;
2.进入下载文件夹,找到下载的文件,运行如下命令解压
tar -xvf apache-maven-2.2.1-bin.tar.gz
解压后的文件夹
- tomcat的https 配置,syslog-ng配置
aichenglong
tomcathttp跳转到httpssyslong-ng配置syslog配置
1) tomcat配置https,以及http自动跳转到https的配置
1)TOMCAT_HOME目录下生成密钥(keytool是jdk中的命令)
keytool -genkey -alias tomcat -keyalg RSA -keypass changeit -storepass changeit
- 关于领号活动总结
alafqq
活动
关于某彩票活动的总结
具体需求,每个用户进活动页面,领取一个号码,1000中的一个;
活动要求
1,随机性,一定要有随机性;
2,最少中奖概率,如果注数为3200注,则最多中4注
3,效率问题,(不能每个人来都产生一个随机数,这样效率不高);
4,支持断电(仍然从下一个开始),重启服务;(存数据库有点大材小用,因此不能存放在数据库)
解决方案
1,事先产生随机数1000个,并打
- java数据结构 冒泡排序的遍历与排序
百合不是茶
java
java的冒泡排序是一种简单的排序规则
冒泡排序的原理:
比较两个相邻的数,首先将最大的排在第一个,第二次比较第二个 ,此后一样;
针对所有的元素重复以上的步骤,除了最后一个
例题;将int array[]
- JS检查输入框输入的是否是数字的一种校验方法
bijian1013
js
如下是JS检查输入框输入的是否是数字的一种校验方法:
<form method=post target="_blank">
数字:<input type="text" name=num onkeypress="checkNum(this.form)"><br>
</form>
- Test注解的两个属性:expected和timeout
bijian1013
javaJUnitexpectedtimeout
JUnit4:Test文档中的解释:
The Test annotation supports two optional parameters.
The first, expected, declares that a test method should throw an exception.
If it doesn't throw an exception or if it
- [Gson二]继承关系的POJO的反序列化
bit1129
POJO
父类
package inheritance.test2;
import java.util.Map;
public class Model {
private String field1;
private String field2;
private Map<String, String> infoMap
- 【Spark八十四】Spark零碎知识点记录
bit1129
spark
1. ShuffleMapTask的shuffle数据在什么地方记录到MapOutputTracker中的
ShuffleMapTask的runTask方法负责写数据到shuffle map文件中。当任务执行完成成功,DAGScheduler会收到通知,在DAGScheduler的handleTaskCompletion方法中完成记录到MapOutputTracker中
- WAS各种脚本作用大全
ronin47
WAS 脚本
http://www.ibm.com/developerworks/cn/websphere/library/samples/SampleScripts.html
无意中,在WAS官网上发现的各种脚本作用,感觉很有作用,先与各位分享一下
获取下载
这些示例 jacl 和 Jython 脚本可用于在 WebSphere Application Server 的不同版本中自
- java-12.求 1+2+3+..n不能使用乘除法、 for 、 while 、 if 、 else 、 switch 、 case 等关键字以及条件判断语句
bylijinnan
switch
借鉴网上的思路,用java实现:
public class NoIfWhile {
/**
* @param args
*
* find x=1+2+3+....n
*/
public static void main(String[] args) {
int n=10;
int re=find(n);
System.o
- Netty源码学习-ObjectEncoder和ObjectDecoder
bylijinnan
javanetty
Netty中传递对象的思路很直观:
Netty中数据的传递是基于ChannelBuffer(也就是byte[]);
那把对象序列化为字节流,就可以在Netty中传递对象了
相应的从ChannelBuffer恢复对象,就是反序列化的过程
Netty已经封装好ObjectEncoder和ObjectDecoder
先看ObjectEncoder
ObjectEncoder是往外发送
- spring 定时任务中cronExpression表达式含义
chicony
cronExpression
一个cron表达式有6个必选的元素和一个可选的元素,各个元素之间是以空格分隔的,从左至右,这些元素的含义如下表所示:
代表含义 是否必须 允许的取值范围 &nb
- Nutz配置Jndi
ctrain
JNDI
1、使用JNDI获取指定资源:
var ioc = {
dao : {
type :"org.nutz.dao.impl.NutDao",
args : [ {jndi :"jdbc/dataSource"} ]
}
}
以上方法,仅需要在容器中配置好数据源,注入到NutDao即可.
- 解决 /bin/sh^M: bad interpreter: No such file or directory
daizj
shell
在Linux中执行.sh脚本,异常/bin/sh^M: bad interpreter: No such file or directory。
分析:这是不同系统编码格式引起的:在windows系统中编辑的.sh文件可能有不可见字符,所以在Linux系统下执行会报以上异常信息。
解决:
1)在windows下转换:
利用一些编辑器如UltraEdit或EditPlus等工具
- [转]for 循环为何可恨?
dcj3sjt126com
程序员读书
Java的闭包(Closure)特征最近成为了一个热门话题。 一些精英正在起草一份议案,要在Java将来的版本中加入闭包特征。 然而,提议中的闭包语法以及语言上的这种扩充受到了众多Java程序员的猛烈抨击。
不久前,出版过数十本编程书籍的大作家Elliotte Rusty Harold发表了对Java中闭包的价值的质疑。 尤其是他问道“for 循环为何可恨?”[http://ju
- Android实用小技巧
dcj3sjt126com
android
1、去掉所有Activity界面的标题栏
修改AndroidManifest.xml 在application 标签中添加android:theme="@android:style/Theme.NoTitleBar"
2、去掉所有Activity界面的TitleBar 和StatusBar
修改AndroidManifes
- Oracle 复习笔记之序列
eksliang
Oracle 序列sequenceOracle sequence
转载请出自出处:http://eksliang.iteye.com/blog/2098859
1.序列的作用
序列是用于生成唯一、连续序号的对象
一般用序列来充当数据库表的主键值
2.创建序列语法如下:
create sequence s_emp
start with 1 --开始值
increment by 1 --増长值
maxval
- 有“品”的程序员
gongmeitao
工作
完美程序员的10种品质
完美程序员的每种品质都有一个范围,这个范围取决于具体的问题和背景。没有能解决所有问题的
完美程序员(至少在我们这个星球上),并且对于特定问题,完美程序员应该具有以下品质:
1. 才智非凡- 能够理解问题、能够用清晰可读的代码翻译并表达想法、善于分析并且逻辑思维能力强
(范围:用简单方式解决复杂问题)
- 使用KeleyiSQLHelper类进行分页查询
hvt
sql.netC#asp.nethovertree
本文适用于sql server单主键表或者视图进行分页查询,支持多字段排序。KeleyiSQLHelper类的最新代码请到http://hovertree.codeplex.com/SourceControl/latest下载整个解决方案源代码查看。或者直接在线查看类的代码:http://hovertree.codeplex.com/SourceControl/latest#HoverTree.D
- SVG 教程 (三)圆形,椭圆,直线
天梯梦
svg
SVG <circle> SVG 圆形 - <circle>
<circle> 标签可用来创建一个圆:
下面是SVG代码:
<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
<circle cx="100" c
- 链表栈
luyulong
java数据结构
public class Node {
private Object object;
private Node next;
public Node() {
this.next = null;
this.object = null;
}
public Object getObject() {
return object;
}
public
- 基础数据结构和算法十:2-3 search tree
sunwinner
Algorithm2-3 search tree
Binary search tree works well for a wide variety of applications, but they have poor worst-case performance. Now we introduce a type of binary search tree where costs are guaranteed to be loga
- spring配置定时任务
stunizhengjia
springtimer
最近因工作的需要,用到了spring的定时任务的功能,觉得spring还是很智能化的,只需要配置一下配置文件就可以了,在此记录一下,以便以后用到:
//------------------------定时任务调用的方法------------------------------
/**
* 存储过程定时器
*/
publi
- ITeye 8月技术图书有奖试读获奖名单公布
ITeye管理员
活动
ITeye携手博文视点举办的8月技术图书有奖试读活动已圆满结束,非常感谢广大用户对本次活动的关注与参与。
8月试读活动回顾:
http://webmaster.iteye.com/blog/2102830
本次技术图书试读活动的优秀奖获奖名单及相应作品如下(优秀文章有很多,但名额有限,没获奖并不代表不优秀):
《跨终端Web》
gleams:http