在要求输入邮箱的文本域,请填写真实的邮件地址。非真实邮件地址,将收不到回复信息。

 分类:JavaScript

JavaScript录音错误浏览器不支持getUserMedia

背景 新项目有一个新的需求,需要用到浏览器录音。在本地进行测试的时候并没有发现问题,部署以后访问就出现了如下错误: 浏览器不支持 getUserMedia 经过了解得知getUserMedia 是默认不支持 http 访问的,必须要用 https 协议且需要合法的域名。 解决方法 使用https协议访问 申请域名并配置SSL证书,实现HTTPS协议请求访问即可避免此问题 配置浏览器临时解决方案 打开谷歌浏览器,在地址栏中输入chrome://flags/#unsafely-treat-insecure-origin-as-secure后并回车可见如下内容: 将目标网站输入到Insecure origins treated as secure中,然后将Disabled下拉改为Enabled。使用此方法即可临时解决无法...

5个月前 (04-30) 471℃ 0评论 0喜欢

Javascript判断当前页面是否处于激活状态

背景 现有一个考试项目,当在浏览器进行考试时需要判断用户是否存在切屏,如果切屏就对当前考试进行自动强制交卷。浏览器中可通过window对象的onblur、onfocus判断,或者document的hidden属性判断。 获取焦点(onfocus)和失去焦点(onblur) 关于是否失焦点,浏览器对象有onfocus 和 onblur事件可以监听。但是触发这两个事件的前提是页面之前是获取焦点的,就是说要是激活的。也就是说页面刚刚渲染完,用户在没有页面上任何操作时,页面是不会正常监听这两个事件的;或者页面在打开状态下,但是触发了onblur之后并无页面操作的情况下也不会正常监听这两个事件。直到,用户操作页面触发focus,之后离开页面才会触发blur,再次点击到当前页面时才会触发focus,如此反复都会触发相应的事件。 onblur 在chrome浏览器下,点击...

2年前 (2022-11-21) 2950℃ 0评论 5喜欢

js Date 操作之神奇的 date

Date 对象算是较常用的对象之一,但很多人完全不会操作,就算一些简单的操作也用 moment 而不自己尝试一下。本次分享下 Date 中的 date 使用技巧,希望能给大家启发。 MDN官网介绍 setDate()方法根据本地时间来指定一个日期对象的天数。如果 dayValue 超出了月份的合理范围,setDate 将会相应地更新 Date 对象。例如,如果为 dayValue 指定0,那么日期就会被设置为上个月的最后一天。 获取月份天数 // 获取月份天数 function getMonthDayCount(year, month) { return new Date(year, month, 0).getDate(); } console.log(getMonthDayCount(2017, 10)); // 31 Date 第三个参数的本质跟 setDate 是...

6年前 (2018-12-03) 820℃ 0评论 3喜欢

JQuery特效单击漂浮文字

在一些博客上遇到点击鼠标的时候有文字或者符号漂浮,感觉挺不错的。如下图: JQuery代码实现类似效果: var a_idx = 0; jQuery(document).ready(function($) { $("body").click(function(e){ var a = new Array("Javascript", "DotNet", "C#", "Java", "C", "C++", "HTML", "CSS", "NodeJS", "PHP", "SQL"); var $i = $("<span/>").text(a[a_idx]); a_idx = (a_idx + 1) % a.length; var x = e.pageX, y = e.pageY; $i.css({...

6年前 (2018-11-22) 919℃ 0评论 0喜欢

JavaScript获取URL地址参数

有时候需要通过JavaScript中获取网址中传递的参数,以下就提供两种方法,仅供参考。这个也是很早时候的内容了,由原来的QQ空间整理出来,这里也做下记录。 方法一:正则分析法 function getQueryString(name) { var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i"); var r = window.location.search.substr(1).match(reg); if (r != null) { return unescape(r[2]); } return null; } 调用方法: alert(GetQueryString("参数名1")); alert(GetQueryString(...

6年前 (2018-10-11) 820℃ 0评论 2喜欢

Javascript实现数组类

//数组类 function ArrayList() { this.length = 0; this.array = new Array(); this.Item = function(index) { return this.array[index]; } this.Add = function(value) { this.array[this.length] = value; this.length++; } this.Remove = function(value) { if (this.length >= 1) { for (var i = 0; i < this.length; i++) { ...

6年前 (2018-09-03) 649℃ 0评论 0喜欢

Jquery插件实现outerHTML

$.fn.outerHTML = function() { return (!this.length) ? this: (this[0].outerHTML || (function(el) { var div = document.createElement('div'); div.appendChild(el.cloneNode(true)); var contents = div.innerHTML; div = null; return contents; })(this[0])); } 转载请注明:清风亦平凡 » Jquery插件实现outerHTML ...

8年前 (2016-11-09) 844℃ 0评论 0喜欢

require.js的用法

一、为什么要用require.js? 最早的时候,所有Javascript代码都写在一个文件里面,只要加载这一个文件就够了。后来,代码越来越多,一个文件不够了,必须分成多个文件,依次加载。下面的网页代码,相信很多人都见过。 <script src="1.js"></script> <script src="2.js"></script> <script src="3.js"></script> <script src="4.js"></script> <script src="5.js"></script> <script src="6.js"></script> 这段代码依次加载多个js文件。 这样的写法有很大的缺点。首先,加载...

8年前 (2016-08-22) 1013℃ 0评论 0喜欢

javascript实现的iframe数据共享接口

在iframe与父窗口或者与子窗口传递数据是一个麻烦的事情,如果我们能够写一个一劳永逸的接口那就再方便不过了,下面就来简答介绍一下如何实现此功能。原理就是将数据缓存早window.top这个窗口,这样无论子窗口父窗口的层次如何变化,数据总是存在不会变化的。 var dataShare = { setData: function(name, value) { var top = window.top, cache = top['_CACHE'] || {}; top['_CACHE'] = cache; return value ? cache[name] = value: cache[name]; }, removeData: function(name) { var...

8年前 (2016-08-17) 1103℃ 0评论 0喜欢

JavaScript获取用户的DPI

在某些情况下,需要获得用户的DPI。以下方法是用JavaScript实现获取用户的DPI。 function getDPI() { var arrDPI = new Array; var devicePixelRatio = window.devicePixelRatio || 1; var tmpNode = document.createElement("DIV"); tmpNode.style.cssText = "height: 1in; left: -100%; position: absolute; top: -100%; width: 1in;"; document.body.appendChild(tmpNode); arrDPI[0] = parseInt(tmpNode.o...

8年前 (2016-07-02) 2136℃ 0评论 3喜欢

JavaScript实现金额转为大写

此方法为招商银行网上银行对金额进行大写的转换方法。 function ConvertUpperMoney(whole) { //金额转换。输入数字字符串,低至分位,高位不为零 var GBK_unit1 = "分角"; var GBK_unit2 = "圆拾佰仟"; var GBK_unit3 = "万拾佰仟" var GBK_unit4 = "亿拾佰仟"; var GBK_num = "零壹贰叁肆伍陆柒捌玖"; var section1 = ""; if (whole.length - 2 >= 0) section1 = whole.substr(whole.length - 2, 2); else section1 = whole.substr(0, whole.length); ...

8年前 (2016-07-02) 722℃ 0评论 0喜欢

Javascript简单实现HTML元素抖动效果

<!doctype html> <html> <head> <meta charset="utf-8"> <title></title> <script type="text/javascript">function shake(id) { var style = document.getElementById(id).style, p = [4, 8, 4, 0, -4, -8, -4, 0], fx = function() { style.marginLeft = p.shift() + 'px'; if (p.length <= 0) { style.marginLeft = 0; ...

8年前 (2016-07-02) 925℃ 0评论 1喜欢

TpLink路由器登录密码加密算法

var TpLinkPassWordEnCode = { _strDe: "RDpbLfCPsJZ7fiv", _dic: "yLwVl0zKqws7LgKPRQ84Mdt708T1qQ3Ha7xv3H7NyU84p21BriUWBU43odz3iP4rBL3cD02KZciX" + "TysVXiV8ngg6vL48rPJyAUw0HurW20xqxv9aYb4M9wK1Ae0wlro510qXeU07kV57fQMc8L6aLgML" + "wygtc0F10a0Dg70TOoouyFhdysuRMO51yY5ZlOZZLEal1h0t9YQW0Ko7oBwmCAHoic4HYbUyVeU3" + "sfQ1xtXcPcf1aT303wAQhv66qzW", securityEncode: func...

8年前 (2016-07-01) 1620℃ 0评论 5喜欢

JavaScript对象深浅拷贝

浅拷贝: function extendCopy(p) {     var c = {};     for (var i in p) {       c[i] = p[i];     }     c.uber = p;     return c; } 深拷贝: function deepCopy(p, c) {     var c = c || {};     for (var i in p) {       if (typeof p[i] === 'object') { c[i] = (p[i].constructor === Array) ? [] : {}; deepCopy(p[i], c[i]);       ...

8年前 (2016-07-01) 741℃ 0评论 0喜欢

javaScript日期格式化

/* var d=new Date(); console.log(d.toString()); //2012-7-27 9:26:52 console.log(d.toString("")); //2012-7-27 9:26:52 console.log(d.toString("yyyy-MM-dd HH:mm:ss")); //2012-07-27 09:26:52 console.log(d.toString("yyyy年MM月dd日 HH:mm:ss")); //2012年07月27日 09:26:52 console.log(d.toString("yyyy-MM-dd HH:mm:ss fff")); //2012-07-27 09:26:52 237 console.log(d.toString("yyyy年 MMM dd ...

8年前 (2016-07-01) 837℃ 0评论 0喜欢