1. addEventListener中的事件如果移除(removeEventListener)的话不能在事件中执行bind(this)否则会移除无效!
  2. // selectCurrent()
    // copy("example...") // function sleep (ms) {
    // return new Promise((resolve) => {
    // setTimeout(() => {
    // resolve('sleep for ' + ms + ' ms');
    // }, ms);
    // });
    // }
    // async function selectCurrent () {
    // var reselectPrevious // await sleep(2000)
    // reselectPrevious = deselectCurrent();
    // console.log("first") // await sleep(2000)
    // reselectPrevious()
    // console.log("last")
    // } var defaultMessage = "Copy to clipboard: #{key}, Enter"; function format(message) {
    var copyKey = (/mac os x/i.test(navigator.userAgent) ? "⌘" : "Ctrl") + "+C";
    return message.replace(/#{\s*key\s*}/g, copyKey);
    } /**
    * interface Options {
    * debug?: boolean;
    * message?: string;
    * }
    * @param {string} text
    * @param {Options} options
    */
    function copy(text, options) {
    var debug,
    message,
    reselectPrevious,
    range,
    selection,
    mark,
    success = false;
    if (!options) {
    options = {};
    }
    debug = options.debug || false; try {
    reselectPrevious = deselectCurrent(); range = document.createRange();
    selection = document.getSelection(); mark = document.createElement("span");
    mark.textContent = text;
    // reset user styles for span element
    mark.style.all = "unset";
    // prevents scrolling to the end of the page
    mark.style.position = "fixed";
    mark.style.top = 0;
    mark.style.clip = "rect(0, 0, 0, 0)";
    // used to preserve spaces and line breaks
    mark.style.whiteSpace = "pre";
    // do not inherit user-select (it may be `none`)
    mark.style.webkitUserSelect = "text";
    mark.style.MozUserSelect = "text";
    mark.style.msUserSelect = "text";
    mark.style.userSelect = "text";
    mark.addEventListener("copy", function (e) {
    e.stopPropagation();
    }); document.body.appendChild(mark); range.selectNodeContents(mark);
    selection.addRange(range); var successful = document.execCommand("copy");
    if (!successful) {
    throw new Error("copy command was unsuccessful");
    }
    success = true;
    } catch (err) {
    debug && console.error("unable to copy using execCommand: ", err);
    debug && console.warn("trying IE specific stuff");
    try {
    window.clipboardData.setData("text", text);
    success = true;
    } catch (err) {
    debug && console.error("unable to copy using clipboardData: ", err);
    debug && console.error("falling back to prompt");
    message = format("message" in options ? options.message : defaultMessage);
    window.prompt(message, text);
    }
    } finally {
    if (selection) {
    if (typeof selection.removeRange == "function") {
    selection.removeRange(range);
    } else {
    selection.removeAllRanges();
    }
    } if (mark) {
    document.body.removeChild(mark);
    }
    reselectPrevious();
    } return success;
    } // 取消选择当前浏览器选择并返回恢复选择的功能。 toggleSelection
    function deselectCurrent () {
    // 返回一个Selection对象,该对象表示用户选择的文本范围或插入符的当前位置。
    var selection = document.getSelection();
    if (!selection.rangeCount) {
    return function () {};
    }
    var active = document.activeElement; var ranges = [];
    for (var i=0; i<selection.rangeCount; i++) {
    ranges.push(selection.getRangeAt(i));
    } switch (active.tagName.toUpperCase()) { // .toUpperCase handles XHTML
    case 'INPUT':
    case 'TEXTAREA':
    active.blur();
    break;
    default:
    active = null;
    break;
    } selection.removeAllRanges();
    return function () {
    selection.type === 'Caret' && selection.removeAllRanges() if (!selection.rangeCount) {
    ranges.forEach(function(range) {
    selection.addRange(range);
    });
    } active && active.focus();
    }
    }

    点击复制事件封装代码:

  3. document.body.addEventListener(
    'touchmove',
    function(e) {
    if (e._isScroller) return
    // 阻止默认事件
    e.preventDefault()
    },
    {
    passive: false
    }
    )

    iOS上拉边界下拉出现空白解决方案:

  4. window.addEventListener('resize', function() {
    if (
    document.activeElement.tagName === 'INPUT' ||
    document.activeElement.tagName === 'TEXTAREA'
    ) {
    window.setTimeout(function() {
    if ('scrollIntoView' in document.activeElement) {
    document.activeElement.scrollIntoView(false)
    } else {
    document.activeElement.scrollIntoViewIfNeeded(false)
    }
    }, 0)
    }
    })

    IOS 键盘弹起挡住原来的视图:

  5. FastClick.prototype.focus = function(targetElement) {
    var length
    if (
    deviceIsIOS &&
    targetElement.setSelectionRange &&
    targetElement.type.indexOf('date') !== 0 &&
    targetElement.type !== 'time' &&
    targetElement.type !== 'month'
    ) {
    length = targetElement.value.length
    targetElement.setSelectionRange(length, length)
    targetElement.focus()
    } else {
    targetElement.focus()
    }
    }

    IOS12 输入框难以点击获取焦点,弹不出软键盘(fastclick.js 对 IOS12 的兼容性,可在 fastclick.js 源码或者 main.js 做以下修改):

JS 手札记的更多相关文章

  1. 原生js手动轮播图

    手动轮播图,为轮播图中的一种,轮播图主要有无缝轮播,手动轮播,延迟轮播,切换轮播等等... 轮播图主要用于展现图片,新出商品,词条,又能美观网页.給网页中增加动态效果. 手动轮播,是小编认为最简单的一 ...

  2. 原生html、js手写 radio与checkbox 美化

    原生html.js手写 radio与checkbox   美化 html <!DOCTYPE html> <html> <head> <meta charse ...

  3. 常见的JS手写函数汇总(代码注释、持续更新)

    最近在复习面试中常见的JS手写函数,顺便进行代码注释和总结,方便自己回顾也加深记,内容也会陆陆续续进行补充和改善. 一.手写深拷贝 <script> const obj1 = { name ...

  4. touch.js 手机端的操作手势

    使用原生的touchstart总是单击.长按有冒泡冲突事件,发现百度在几年开源的touch.js库,放在现在来解决手机端的操作手势,仍然很好用.

  5. 五四青年节,今天要学习。汇总5道难度不高但可能遇到的JS手写编程题

    壹 ❀ 引 时间一晃,今天已是五一假期最后一天了,没有出门,没有太多惊喜与意外.今天五四青年节,脑子里突然想起鲁迅先生以及悲欢并不相通的话,我的五一经历了什么呢,忍不住想说那大概是,父母教育孩子大声嚷 ...

  6. 浅谈时钟的生成(js手写代码)

    在生成时钟的过程中自己想到布置表盘的写法由这么几种: 当然利用那种模式都可以实现,所以我们要用一个最好理解,代码有相对简便的方法实现 1.利用三角函数 用js在三角函数布置表盘的过程中有遇见到这种情况 ...

  7. [js开源组件开发]js手机端浮层控件,并有多种弹出小提示,兼容pc端浏览器

    js dialog组件,包含alert和confirm的实现 本组件所有的资源均在github上可以查看源代码 GitHub 本dialog的组件的例子请在这里查看 demo dialog js di ...

  8. 轮播图--JS手写

    轮播图基本每个网站都会有,也有很多的JQuery插件可以用,这里是用JS代码写的. @{ Layout = null; } <!DOCTYPE html> <html> < ...

  9. js手写图片查看器(图片的缩放、旋转、拖拽)

    在做一次代码编辑任务中,要查看图片器.在时间允许的条件下,放弃了已经封装好的图片jq插件,现在自己手写js实现图片的缩放.旋转.推拽功能! 具体代码如下: <!DOCTYPE html> ...

随机推荐

  1. OpenTelemetry-可观察性的新时代

    有幸在2019KubeCon上海站听到Steve Flanders关于OpenTelemetry的演讲,之前Ops领域两个网红项目OpenTracing和OpenCensus终于走到了一起,可观察性统 ...

  2. Android实战:手把手实现“捧腹网”APP(二)-----捧腹APP原型设计、实现框架选取

    Android实战:手把手实现"捧腹网"APP(一)-–捧腹网网页分析.数据获取 Android实战:手把手实现"捧腹网"APP(二)-–捧腹APP原型设计.实 ...

  3. sql —— 自动增长列

    1.设置自动增长列 设置完毕添加数据这个字段就不用再手动添加了,会从10001开始,每条数据自动加1.

  4. Java中try catch finally语句中含return语句的执行情况总结-编程陷阱

    前言:有java编程基础的人对java的异常处理机制都会有一定了解,而且可能感觉使用起来也比较简单,但如果在try catch finally语句块中遇到return语句,开发者可能就会遇到一些逻辑问 ...

  5. python 调用API时异常捕获的技巧

  6. CS第三方控件 标签: 总结 2016-04-09 11:51 1398人阅读 评论(27) 收藏

    大家都知道,我现在在做CS的项目,现在是需求频变啊,心里好苦,做了这么久,还是涨了一点点见识的,下面就介绍一下自己最近用到的几款CS的第三方控件. DockPanel 想必大家都用过VS,那么想一下V ...

  7. mysql 计算两个时间之间有多少分钟

    SELECT TIMESTAMPDIFF(MINUTE, (DATE_FORMAT('2015-08-12 10:38:00','%Y-%m-%d %H:%i')), (DATE_FORMAT('20 ...

  8. 60.0.1(64位)windows版 uploadify使用有问题

    http://mozilla.com.cn/thread-403024-1-1.html 60.0.1(64位)版,在使用uploadify插件,上传附件时,上传没有问题,可以成功,但执行上传成功后的 ...

  9. day5-python之递归与二分法

    一.递归的定义 递归调用是函数嵌套调用的一种特殊形式,函数在调用时,直接或间接调用了自身,就是递归调用 二.递归分为两个阶段:递推,回溯 age(5) = age(4) + 2 age(4) = ag ...

  10. WebSocket 实时更新mysql数据到页面

    使用websocket的初衷是,要实时更新mysql中的报警信息到web页面显示 没怎么碰过web,代码写的是真烂,不过也算是功能实现了,放在这里也是鞭策自己,web也要多下些功夫 准备 引入依赖 & ...