当前位置: 首页 > news >正文

爱站工具包官网百度搜索引擎优化详解

爱站工具包官网,百度搜索引擎优化详解,东莞厚街镇疫情最新消息,阜阳做网站keydown,keyup,keypress 事件默认是给页面上可以聚焦的元素绑定键盘事件,例如input输入框,点击输入框即代表聚焦在该元素上。那么想要给div或者其他不能聚焦的元素上使用键盘事件怎么处理呢?这里用到tabindex属性。 …

keydown,keyup,keypress

事件默认是给页面上可以聚焦的元素绑定键盘事件,例如input输入框,点击输入框即代表聚焦在该元素上。那么想要给div或者其他不能聚焦的元素上使用键盘事件怎么处理呢?这里用到tabindex属性。

它接受一个整数作为值,具有不同的结果,具体取决于整数的值:

  • tabindex=负值 (通常是 tabindex=“-1”),表示元素是可聚焦的,但是不能通过键盘导航来访问到该元素,用 JS
    做页面小组件内部键盘导航的时候非常有用。
  • tabindex=“0” ,表示元素是可聚焦的,并且可以通过键盘导航来聚焦到该元素,它的相对顺序是当前处于的 DOM 结构来决定的。
  • tabindex=正值,表示元素是可聚焦的,并且可以通过键盘导航来访问到该元素;它的相对顺序按照 tabindex
    的数值递增而滞后获焦。如果多个元素拥有相同的 tabindex,它们的相对顺序按照他们在当前 DOM 中的先后顺序决定。
<div class="key-even" id="editor" tabindex="-1">keyDown
</div>

添加上 tabindex 属性后,此时div表示可以聚焦,但是想要触发键盘事件还需要调用 dom 的 focus() 方法,表示页面聚焦在该元素上,这样就可以触发键盘事件了。

const dom = document.getElementById('editor')
dom.addEventListener('click', this.domClick(dom))
dom.addEventListener('keydown', this.keyDown)domClick(dom) {dom.focus()
},
keyDown(e) {console.log(e.keyCode)
}

绑定事件的方式可以改变,主要是讲述 tabindex 属性的用法及作用。

el-Cascader 源码解读:最后一张图片中,li中绑定的tabindex,使的li可以聚焦,

packages/cascader-panel/src/cascader-panel.vue

<template><div:class="['el-cascader-panel',border && 'is-bordered']"@keydown="handleKeyDown"><span>这个地址:element-ui/packages/cascader-panel</span><cascader-menuref="menu"v-for="(menu, index) in menus":index="index":key="index":nodes="menu"></cascader-menu></div>
</template>
    handleKeyDown(e) {console.log('操作键盘是这里---》', e.target)const { target, keyCode } = e;switch (keyCode) {case KeyCode.up:const prev = getSibling(target, -1);focusNode(prev);break;case KeyCode.down:const next = getSibling(target, 1);focusNode(next);break;case KeyCode.left:const preMenu = this.$refs.menu[getMenuIndex(target) - 1];if (preMenu) {const expandedNode = preMenu.$el.querySelector('.el-cascader-node[aria-expanded="true"]');focusNode(expandedNode);}break;case KeyCode.right:const nextMenu = this.$refs.menu[getMenuIndex(target) + 1];if (nextMenu) {const firstNode = nextMenu.$el.querySelector('.el-cascader-node[tabindex="-1"]');focusNode(firstNode);}break;case KeyCode.enter:checkNode(target);break;case KeyCode.esc:case KeyCode.tab:this.$emit('close');break;default:return;}},

packages/cascader-panel/src/cascader-node.vue
在这里插入图片描述

http://www.mmbaike.com/news/48408.html

相关文章:

  • 海外音乐类网站做的比较好的百度如何搜索网址
  • 网站建设的后期维护费用seo行业网
  • 黄骅港怎么读广东搜索引擎优化
  • 猪八戒wordpress重庆旅游seo整站优化
  • 北京网站优化页面网站推广的营销策划方案
  • 盗版网站是如何做的网站seo案例
  • 商场网站开发的项目分析温州seo按天扣费
  • 邵阳网站优化新手网络推广怎么干
  • 设计网站企业网站建设公司小程序推广的十种方式
  • 四川大良网站建设搜索引擎入口大全
  • 使用php做的网站免费的网页制作软件
  • 青岛知名网站建设公司长尾词seo排名优化
  • 做网站 seo百度推广优化排名
  • 厦门规划建设局网站公司的网站
  • 网站建设的步骤以及流程东莞网站seo推广
  • 深圳网站建设微信商城开发新东方烹饪培训学校
  • 洛阳做网站的公司一个具体网站的seo优化方案
  • asp怎么做网站重庆百度seo整站优化
  • 温州做网站建设推广搜索引擎
  • 北京 网站建设 京icp兰州搜索引擎优化
  • 企业服务官网模板seo管理系统培训
  • 个人电影网站做APP违法吗58和百度哪个推广效果好
  • 线上设计师都在哪挣钱重庆seo团队
  • 西安有哪些网站建设公司好友情链接格式
  • 网站搭建修改收费依据google谷歌搜索引擎
  • 沧州做网站哪家好网络推广合同
  • 医疗器械网站怎么做深圳网络公司推广公司
  • 网站建设的基础内容短视频询盘获客系统
  • 淄博百度网站建设信息流优化师前景
  • wordpress logo大小成都网站快速排名优化