最近在看 AOM(Accessibility Object Model) 相关的草案,草案推出一两年了,发现还没有相关的中文文档或者博客谈到这个,看来国内做的人还是太少了,一般也只有大厂会去跟进这一块。下面我就介绍 AOM 相关的特性,内容主要翻译自草案,也会加上自己的一些理解,同时复现草案中的一些 Demo。

名词释义:下文中的无障碍指 Accessibility,可访问性指 Accessiable。

什么是 AOM

AOM(Accessibility Object Model),直译过来就是无障碍对象模型。AOM 提供了一系列的 JavaScript API,允许开发人员修改 HTML 页面的可访问性树(Accessibility Tree),换句话说:它允许开发者直接访问可访问性树。

这是什么意思呢?举个简单的例子,如果需要为一个 <div> 添加一个 role="button" 的属性,以往的做法是使用 setAttribute 设置相关属性:

el.setAttribute("role", "button")

而有了 AOM,我们可以更加直接地设置它的 role 属性:

el.role = "button"

上面两种写法的渲染出来的 DOM 结构是相同的:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-NQj8QpdR-1596977616340)(https://imgkr2.cn-bj.ufileos.com/8c82e5b9-f0f7-42a7-9553-1583fdafdbb6.png?UCloudPublicKey=TOKEN_8d8b72be-579a-4e83-bfd0-5f6ce1546f13&Signature=R1SL4qakZzob3smWGSQvSyzBalM%253D&Expires=1597062901)]

也就是说,除了现有的 DOM 方法(如setAttribute和getAttribute)之外,可访问性的相关属性有了自己的API,这些 API 设置 并计算成可访问性树的属性值。有了对可访问性信息的直接访问,我们可以在不做标记,也就是不设置标签属性的情况下,设置可访问性属性。另外,也可以为DOM中不存在的东西(比如画布元素的内容)创建可访问性树,测试可访问性可能会得到改善。

这张图很好的解释了 AOM 的渲染过程,DOM 树被翻译成页面的主要视觉和可访问性树,而可访问性树又可以通过一个或多个平台特定的可访问性 API 来访问。

浏览器启用 AOM

Chorme

在地址栏输入 chrome://flags,然后启用 enable-experimental-web-platform-features

Safari

Develop > Experimental Features > Accessibility Object Model

Firefox

about:config accessibility.AOM.enabled = true

AOM 特性

AOM 目前是由 Mozilla、Google 和苹果公司的人员共同提出的,下面先总结一下它的特点。

简化属性

当我们为一些普通的控件添加无障碍功能时,可能需要维护大量的属性。即使是一个简单的禁用按钮,就可能需要使用到 rolearia-label 以及 aria-disabled 等属性。如果状态多了,可能还需要添加更多的属性,这些属性通常需要手动添加,如果属性多的话会变得难以维护。

为了解决这个问题,AOM将允许开发者直接在 JavaScript 中设置元素的可访问性属性。例如,如果要对一个元素设置 aria-expanded,你可以直接在该元素上进行设置。

el.ariaExpanded = true;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uCaOWpNe-1596977616345)(https://imgkr2.cn-bj.ufileos.com/96a19c44-61a4-4888-996e-ed8c6235f177.png?UCloudPublicKey=TOKEN_8d8b72be-579a-4e83-bfd0-5f6ce1546f13&Signature=YB0dirDUj6VGJO1ycDUch6h55L4%253D&Expires=1597062976)]

而在以前,我们需要通过切换标记中的属性值来设置属性。

el.setAttribute("aria-expanded", true)

在 AOM 中,ARIA 属性集将作为 DOM 的属性存在,在 ARIA 1.2 规范中可以找到其 IDL 定义。

当然, 在使用 React 或者 Vue 在内的一些具有虚拟 DOM 的框架时,框架会建议不要直接修改 DOM,让框架来处理 DOM 的变化。在这种应用中,你可以仍在标签中定义相关的无障碍语义属性。针对这种情况,草案也提出了 ElementInternals

ElementInternals

对于自定义组件来说,草案建议开发者通过 ElementInternals 对象提供默认语义。开发者可以使用 ElementInternals 对象来修改自定义元素实例的语义状态,来响应用户交互。

目前,定义组件的无障碍能力时依然需要设置一大堆的属性,上面说到,这样会非常的难以维护。

<custom-tablist><custom-tab selected>Tab 1</custom-tab><custom-tab>Tab 2</custom-tab><custom-tab>Tab 3</custom-tab>
</custom-tablist><!-- 自定义元素 -->
<custom-tablist role="tablist"><custom-tabselectedrole="tab"aria-selected="true"aria-controls="tabpanel-1">Tab 1</custom-tab><custom-tab role="tab" aria-controls="tabpanel-2">Tab 2</custom-tab><custom-tab role="tab" aria-controls="tabpanel-3">Tab 3</custom-tab>
</custom-tablist>

使用 ElementInternals 设置默认语义,自定义元素可以避免去维护一大堆的属性,也可以避免元素在开发者删除 ARIA 属性时失去语义,元素看起来也更加简洁。

class CustomTab extends HTMLElement {constructor() {super();this._internals = customElements.createInternals(this);this._internals.role = "tab";}// 监听 'active' 属性static get observedAttributes() {return ["active"];}connectedCallback() {this._tablist = this.parentElement;}setTabPanel(tabpanel) {if (tabpanel.localName !== "custom-tabpanel" || tabPanel.id === "") return; // fail silentlythis._tabpanel = tabpanel;tabpanel.setTab(this);this._internals.ariaControls = tabPanel; // does not reflect}// ... setters/getters for custom properties which reflect to attributesattributeChangedCallback(name, oldValue, newValue) {switch (name) {case "active":let active = newValue != null;this._tabpanel.shown = active;// When the custom "active" attribute changes,// keep the accessible "selected" state in sync.this._internals.ariaSelected = newValue !== null;if (selected) this._tablist.setSelectedTab(this); // ensure no other tab has "active" setbreak;}}
}customElements.define("custom-tab", CustomTab);

没有ID的关系

在HTML中,id 属性表示了一个元素。举个例子,在表单中,通过将标签的 for 属性指 <input> id,将标签属性与其对应的输入关联起来。在ARIA中,有一些属性需要指向一个 id 或多个id),比如aria-controls 和 aria-describedby。通过AOM,可以直接将元素与其他元素关联起来,而不需要指定一个 id。

正常的情况下:

el.ariaDescribedBy = "id1";

上面的代码渲染出来就变成了

<div aria-describedby="id1"></div>

草案提出可以直接将元素赋予给属性

el.ariaDescribedByElements = [labelElement1, labelElement2];
el.ariaActiveDescendantElement = ownedElement1;

*这个特性目前在 Blink 中实现了

可访问性事件

在 JavaScript 中,有点击、键盘按下和触摸等事件。在某些情况下,这些事件与辅助技术用户的输入之间存在差异。

例如拖动滑块的事件,因为屏幕阅读器用户已经使用 "向左滑动 "和 "向右滑动 "的手势来触发屏幕阅读器的特定命令,所以无法再使用相同的手势来触发其他的事件。因此 AOM 带来了一些特定的事件,以便 AT 可以设计一致的方式让用户执行某些操作,苹果将这些事件称为语义事件。为了用户隐私问题,防止恶意网站利用它们来检测某人是否有视觉或行动障碍,这些事件最终会被转换为 DOM 中的特定事件。

无障碍节点(AccessiableNode)

每个DOM元素都有一个相关的AccessibleNode,允许作者读写可访问属性。这被命名为 “可访问性对象模型”,类似于文档对象模型。

目前随着讨论的深入,这个模型依然存在一些问题。

  • 依赖于可访问性树。

  • 暴露计算出的可访问性树需要在不同的浏览器上对计算树的方式进行标准化。

  • 确定ARIA属性和AccessibleNode属性的优先顺序并没有一个明显的 "正确 "答案。

  • 同样,专门使用 AccessibleNodes 来表达关系也令人困惑。

虚拟无障碍节点(Virtual Accessibility Nodes)

虚拟无障碍节点允许开发者暴露一个虚拟的无障碍节点,这些节点不直接与任何特定的 DOM 元素相关联。

  • 调用 attachAccessibleRoot() 会导致 AccessibleNode 与 Node 关联。返回的 AccessibleNode 形成一个虚拟可访问性树的根。一旦附加了一个 AccessibleRoot,Node的 DOM 子节点就会被隐式地忽略,以实现可访问性。

  • 一个元素只能有一个关联的 AccessibleRoot。

  • 只有 AccessibleNodes 可以作为 AccessibleNodes 子节点。

canvas.attachAccessibleRoot();
let table = canvas.accessibleRoot.appendChild(new AccessibleNode());
table.role = "table";
table.colCount = 10;
table.rowcount = 100;
let headerRow = table.appendChild(new AccessibleNode());
headerRow.role = "row";
headerRow.rowindex = 0;

非 DOM 节点中的可访问性树

在一些非常特殊的情况下,一个 Web 应用程序可能会包含不存在与 DOM 节点中的内容。例如在画布中的一些内容,例如在画布上绘制一个火车站的可用电梯地图,每个电梯都有一个标签,也有一个可以展开的弹窗,这些信息无法被读屏软件识别。使用AOM,你可以定义一个包含所有标签和扩展状态的无障碍树。然后这些信息将被传达给 AT(Acoustically Transparent),以便视障用户可以理解它们。

测试

虽然现在有类似于 a11y-lint 的检测工具,但是这种工具的原理是去解析 html / jsx 标签中的属性,也就是解析 DOM 树上的属性。利用 AOM 可以快速访问 HTML 节点的名称、角色(role)和无障碍状态(state)等 ARIA 无障碍属性,这个功能会让无障碍的检测变得更好。

现状

表格更新于: July 9, 2019

AOM的规范仍在制定中,实现也在进行中,各种浏览器也都实现了部分的 AOM,目前最多实现的部分是属性的映射。

如果启用 AOM 后,你可以打开这个链接,看到你的浏览器对规范中属性反射部分的支持程度。

希望以上内容对你有帮助,你可以点击链接查看草案中的细节。

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

相关文章

  1. 英读廊——一个人的旅行:原汁原味希腊克里特游记

    * 用英语自身来理解和学习英语是最好的方式,《英读廊》是《满庭说英语》中的拓展阅读系列,这一系列的文章力求帮助大家在英语阅读能力上有所提升,并树立英语思维; * 推荐的阅读的方法是:先原文,适当看解析阅读,还有疑惑再看双语对照。 * 解析中英语单词的音标使用Dictco…...

    2024/5/4 20:07:17
  2. 10 监听器 watch

    被监听的变量或对象发生改变就执行相应的方法,不建议过多使用,影响性能。 例如: 监听变量:监听数组:反序:...

    2024/4/29 7:16:49
  3. IDM下载---一键安装版

    IDM下载器 1.平时我们在下载一些外网上面的文件或者网盘上的文件的时候,那个速度那叫一个惨不忍睹.下面我将分享一个我个人正在使用的IDM下载器,下载链接我会放在本文下面,希望对大家有帮助。 这里我就不多解释IDM的原理-----有想法的朋友可以去度娘 2. 使用步骤 1.下载好文…...

    2024/4/29 7:16:24
  4. 【学习笔记】:SpringBoot集成Swagger2

    一、认识Swagger Swagger 是一个规范和完整的框架,用于生成、描述、调用和可视化 RESTful 风格的 Web 服务。是当前最好用的Restful API文档生成的开源项目。官网:https://swagger.io/ 直接运行,在线测试API 支持多种语言 (如:Java,PHP等) Restful Api 文档在线自动生成…...

    2024/4/29 7:16:31
  5. 笔记本内存条翻车日记(内存插槽突然不识别)及解决方案

    经过:上几周不知何时,我的丐版联想小新潮笔记本内存突然不识别(板载4GB正常工作另外单独一个内存插槽最高支持8GB,此插槽不识别后就只有板载4GB内存了) 17年时基本买的笔记本出场4GB基本上是标配,现在笔记本出厂没有8GB都不好意思卖,这个硬件问题折腾了将近一个月,有些…...

    2024/5/3 3:51:03
  6. 电子客票打印换开

    电子客票打印换开 作者:代富强 撰写日期:2020.8.8 电子客票打印换开:电子客票打印换开功能需要同时满足发票状态为已开发票和票联状态为可供使用的订单才可以使用,否则提示未满足条件不可打印换开。在订单显示页面的视图里根据之前设下的onclick写下打印换开的方法:func…...

    2024/5/4 1:05:03
  7. C#开发要注意的基础基础知识点

    开发要注意的基础基础知识点 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~开发工具与关键技术:Visual Studio 2015 与 C#作者:黄富滔撰写时间:2020年08月06日~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~…...

    2024/4/29 7:16:29
  8. R开发(part2)--R语言中的数学计算

    学习笔记,仅供参考,有错必纠 参考自:《R的极客理想》-- 张丹文章目录R开发R语言中的数学计算对数加权平均、连乘、差分、秩、任意数、全体数阶乘、组合、排列累加、累乘、最小累积、最大累积正弦、余弦、正切、反正弦、反余弦、反正切复数方程计算R开发R语言中的数学计算对数…...

    2024/4/29 7:16:04
  9. HTML导出生成PDF

    public class PDFHelper { /// /// html转pdf /// /// 文件存储路径 public static string BaoJiaHtml(string train_body, string faceto, string train_content, string start_time, string end_time, string actual_join_number, string img_src, string kcjsmyd, string …...

    2024/4/29 7:16:04
  10. 大数据私房菜--impala实战

    1 业务背景 现有收集到用户的页面点击行为日志数据,数据格式如下: 用户id, 点击时间 user_id click_time A,2020-05-15 01:30:00 A,2020-05-15 01:35:00 A,2020-05-15 02:00:00 A,2020-05-15 03:00:10 A,2020-05-15 03:05:00 B,2020-05-15 02:03:00 B,2020-05-15 02:29:40 B,…...

    2024/4/29 7:16:03
  11. MVC开发要注意的基础基础知识点

    开发要注意的基础基础知识点 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~开发工具与关键技术:Visual Studio 2015 与 C#作者:黄富滔撰写时间:2020年08月06日~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~…...

    2024/4/29 7:15:57
  12. 手势识别-mid-air凌空手势识别研究

    本文从凌空手势识别出发,介绍凌空手势的特点及研究内容,以一篇论文为中心,展开详细的关于凌空手势识别的研究内容。Lets go~一、mid-air 凌空手势识别1.凌空手势(mid-air gestures):非接触式、通过用户自然地利用手指、手腕、手臂动作表达其交互意图(例如“指”、“挥手…...

    2024/4/29 2:51:35
  13. 统计模式识别学习笔记(二)

    从极大似然和后验的角度谈基本决策 在阅读这部分知识前,假设各位已经学习过概率论与数理统计,并能够较好的应用这部分知识。设CCC个类ϖ1,...,ϖC\varpi_1,...,\varpi_Cϖ1​,...,ϖC​分别具有先验概率p(ϖ1),...,p(ϖC)p(\varpi_1),...,p(\varpi_C)p(ϖ1​),...,p(ϖC​)。…...

    2024/4/29 7:15:51
  14. Linux安装和基础命令

    Linux安装 linux总结: 1.安装系统 (1)VMWare(2)CentOS安装(3)VMTools安装运行完 ./vmware-install.pl 一路回车2.网络配置 查看ip地址和网关 在虚拟机左上角有一个编辑,编辑里面有一个虚拟网络编辑器,点开找到一个VMnet8点击,在中间位置有一个NAT设置点击,里面就能查…...

    2024/4/29 7:15:51
  15. Linux服务管理-lnmp

    lnmp 文章目录lnmp1. lnmp简介2. lnmp的优点3. lnmp环境搭建3.1 安装nginx3.2 安装mysql3.3 安装php3.4 配置nginx4. 用lnmp架构部署zabbix4.1 zabbix服务端安装4.2 zabbix服务端配置4.3 zabbix服务端web界面安装与配置4.3.1 zabbix web界面安装前配置4.3.2 安装zabbix web界面…...

    2024/4/29 7:15:47
  16. SSM搭建过程(idea详细)

    一.搭建环境1.首先创建数据库和表结构create database ssm; use ssm; create table account( id int primary key auto_increment,name varchar(20), money varchar(20) );2.创建maven的web工程导入依赖<properties><project.build.sourceEncoding>UTF-8</p…...

    2024/4/29 7:15:48
  17. docker安装及测试脚本(ubuntu)

    #!/bin/bash #获取用户名 [ `pwd` == /root ] && hn="root@$(hostname):~#" || hn="root@$(hostname):`pwd`#" d (){echo -e "\033[1m$hn$dd\033[0m" } a (){ sleep 1 } c (){echo -e "\033[32m$cc\033[0m" } #检查网络 pin…...

    2024/5/4 3:42:15
  18. Apache httpd mod_wsgi Nginx uWSGI学习笔记

    以下所总结仅是学习记录,如有不对的部分,还请及时指出,十分感谢 参考文档目录都在末尾写出了作者的链接,有兴趣的可以直接点击 文章有点长,建议收藏后查看 Apache httpd 简介 Apache HTTPD又可以简称为httpd或者Apache,它是Internet使用最广泛的web服务器之一,使用Apach…...

    2024/5/3 13:00:51
  19. Vmware 新建虚拟机点启动时出现“......无法连接到虚拟机”错误

    最近用VMware 15.5 安装Ubuntu虚拟机,首先安装VMware时提示了某个错误(具体错误内容忘记了)导致安装不上,百度了一下说是缺少VC++ 2015驱动库,于是网上下载安装了个VC++ 2015,然后成功将VMware装上。然后新建一个Ubuntu虚拟机,新建完成之后点击“启动”,就出现“......…...

    2024/4/29 7:15:35
  20. 2020年了 你还不懂LNMP与LAMP嘛?两分钟带你深入了解两者的区别~~

    LAMP lamp 的全称是linux + apache + mysql +php 使用的是Apache,Apache是世界是用排名第一的Web服务器软件,其几乎可以在所有广泛使用的计算机平台上运营,由于其跨平台和安全性被广泛使用,是最流行的Web服务端软件之一。 LNMP lnmp 的全称是linux + nginx + mysql + php (…...

    2024/4/29 7:15:25

最新文章

  1. 拼多多怎么推广才有效果

    拼多多店铺的有效推广需要综合考虑多个方面&#xff0c;包括优化店铺信息、商品详情、参与平台活动、利用社交媒体、精准营销和客户服务等。具体如下&#xff1a; 拼多多推广可以使用3an推客。3an推客&#xff08;CPS模式&#xff09;给商家提供的营销工具&#xff0c;由商家自…...

    2024/5/4 20:44:49
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/3/20 10:50:27
  3. Spring集成MyBatis

    基本准备 创建Dynamic Web Project 引入相关jar包 Spring框架相关jar包 MyBatis连接Spring相关jar包 连接MySQL驱动包 JSTL标签库包 添加db.properties文件&#xff0c;该属性文件配置连接数据库相关信息 drivercom.mysql.jdbc.Driver urljdbc:mysql://localhost:3306/myba…...

    2024/4/30 17:16:43
  4. 论文阅读AI工具链

    文献检索 可以利用智谱清言来生成合适的文献检索式&#xff0c;并根据需要不断调整。 谷歌学术 在Google Scholar中进行检索时&#xff0c;您可以使用类似的逻辑来构建您的搜索式&#xff0c;但是语法会有所不同。Google Scholar的搜索框接受普通的文本搜索&#xff0c;但是…...

    2024/5/3 14:44:57
  5. 416. 分割等和子集问题(动态规划)

    题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义&#xff1a;dp[i][j]表示当背包容量为j&#xff0c;用前i个物品是否正好可以将背包填满&#xff…...

    2024/5/4 12:05:22
  6. 【Java】ExcelWriter自适应宽度工具类(支持中文)

    工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...

    2024/5/4 11:23:32
  7. Spring cloud负载均衡@LoadBalanced LoadBalancerClient

    LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon&#xff0c;直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件&#xff0c;我们讨论Spring负载均衡以Spring Cloud2020之后版本为主&#xff0c;学习Spring Cloud LoadBalance&#xff0c;暂不讨论Ribbon…...

    2024/5/4 14:46:16
  8. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

    一、背景需求分析 在工业产业园、化工园或生产制造园区中&#xff0c;周界防范意义重大&#xff0c;对园区的安全起到重要的作用。常规的安防方式是采用人员巡查&#xff0c;人力投入成本大而且效率低。周界一旦被破坏或入侵&#xff0c;会影响园区人员和资产安全&#xff0c;…...

    2024/5/3 16:00:51
  9. VB.net WebBrowser网页元素抓取分析方法

    在用WebBrowser编程实现网页操作自动化时&#xff0c;常要分析网页Html&#xff0c;例如网页在加载数据时&#xff0c;常会显示“系统处理中&#xff0c;请稍候..”&#xff0c;我们需要在数据加载完成后才能继续下一步操作&#xff0c;如何抓取这个信息的网页html元素变化&…...

    2024/5/4 12:10:13
  10. 【Objective-C】Objective-C汇总

    方法定义 参考&#xff1a;https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...

    2024/5/3 21:22:01
  11. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

    &#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】&#x1f30f;题目描述&#x1f30f;输入格…...

    2024/5/3 23:17:01
  12. 【ES6.0】- 扩展运算符(...)

    【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数&#xff0…...

    2024/5/4 14:46:12
  13. 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?

    文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕&#xff0c;各大品牌纷纷晒出优异的成绩单&#xff0c;摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称&#xff0c;在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁&#xff0c;多个平台数据都表现出极度异常…...

    2024/5/4 14:46:11
  14. Go语言常用命令详解(二)

    文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令&#xff0c;这些命令可以帮助您在Go开发中进行编译、测试、运行和…...

    2024/5/4 14:46:11
  15. 用欧拉路径判断图同构推出reverse合法性:1116T4

    http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b&#xff0c;我们在 a i a_i ai​ 和 a i 1 a_{i1} ai1​ 之间连边&#xff0c; b b b 同理&#xff0c;则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然&#xff0…...

    2024/5/4 2:14:16
  16. 【NGINX--1】基础知识

    1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息&#xff0c;并安装一些有助于配置官方 NGINX 软件包仓库的软件包&#xff1a; apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...

    2024/5/3 16:23:03
  17. Hive默认分割符、存储格式与数据压缩

    目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限&#xff08;ROW FORMAT&#xff09;配置标准HQL为&#xff1a; ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...

    2024/5/4 12:39:12
  18. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

    文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中&#xff0c;传感器和控制器产生大量周…...

    2024/5/4 13:16:06
  19. --max-old-space-size=8192报错

    vue项目运行时&#xff0c;如果经常运行慢&#xff0c;崩溃停止服务&#xff0c;报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中&#xff0c;通过JavaScript使用内存时只能使用部分内存&#xff08;64位系统&…...

    2024/5/4 16:48:41
  20. 基于深度学习的恶意软件检测

    恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞&#xff0c;例如可以被劫持的合法软件&#xff08;例如浏览器或 Web 应用程序插件&#xff09;中的错误。 恶意软件渗透可能会造成灾难性的后果&#xff0c;包括数据被盗、勒索或网…...

    2024/5/4 14:46:05
  21. JS原型对象prototype

    让我简单的为大家介绍一下原型对象prototype吧&#xff01; 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定&#xff0c;每一个构造函数都有一个 prototype 属性&#xff0c;指向另一个对象&#xff0c;所以我们也称为原型对象…...

    2024/5/4 2:00:16
  22. C++中只能有一个实例的单例类

    C中只能有一个实例的单例类 前面讨论的 President 类很不错&#xff0c;但存在一个缺陷&#xff1a;无法禁止通过实例化多个对象来创建多名总统&#xff1a; President One, Two, Three; 由于复制构造函数是私有的&#xff0c;其中每个对象都是不可复制的&#xff0c;但您的目…...

    2024/5/3 22:03:11
  23. python django 小程序图书借阅源码

    开发工具&#xff1a; PyCharm&#xff0c;mysql5.7&#xff0c;微信开发者工具 技术说明&#xff1a; python django html 小程序 功能介绍&#xff1a; 用户端&#xff1a; 登录注册&#xff08;含授权登录&#xff09; 首页显示搜索图书&#xff0c;轮播图&#xff0…...

    2024/5/4 9:07:39
  24. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

    C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...

    2024/5/4 14:46:02
  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