分类: JavaScript

Node如何获取计算机名称

在使用Node.js开发客户端应用时,可能会有获取计算机名的需求,以区分用户的多个设备。

这里所说的计算机名称(ComputerName),也称为设备名称(DeviceName),用户可以自定义自己的设备名称。

在 Windows 系统中,在此电脑(计算机、我的电脑)图标上右键,选择属性可以找到[……]

继续阅读

2023-06-06 Comments (0)
阅读全文

Vue3的setup中使用ref获取dom元素

背景问题

  • 在vue3中input如何获取焦点?
  • vue3 setup语法糖如何获取dom元素?

vue2 的方法

在 vue2 中,在组件上设置 ref 属性之后,就可以通过 this.$refs.ref 访问到对应的 DOM 元素。

<input type="text" ref=[......]

继续阅读

2022-03-11 Comments (0)
阅读全文

一道前端面试题

输入字符串’a(3)b(1)cde(2)f(0)’,得到输出结果:’aaabcdee’。

其中括弧内的数字是括弧前面字母的重复次数;如果字母后面没有括弧,就原样输出(相当于重复1次);括弧内数字为0则不输出。

这道题其实非常简单,但是有多种解题思路,涉及的基本知识点也很多。下面我会按照我觉得由低[……]

继续阅读

2022-01-17 Comments (0)
阅读全文

Vue3 setup使用模板引用$refs

在Vue2中,我们通常这么做实现一个模板引用:

<template>
  <input ref="input" />
</template>

<script>
export default {
  data() {},
  methods: {[......]

继续阅读

Vue 
2021-12-27 Comments (0)
阅读全文

使用 React Hooks 构建一个音频播放器

原文链接:https://letsbuildui.dev/articles/building-an-audio-player-with-react-hooks

今天我们将使用 HTMLAudioElement 接口构建一个基于 React Hooks 的音频播放器组件。这个播放器可以实现音频列表的[……]

继续阅读

2021-09-01 Comments (0)
阅读全文

H5处理全面屏iPhone底部边距

iPhone 从 X 开始使用全面屏,浏览网页的时候底部会有一条遮住可视区域,为了避免H5页面被iPhone底部条遮住,可以采取以下方案。

iPhone自适应底部

首先,iPhone自带了屏幕安全区域的处理策略,可以使用constant和env两个css特性来获取底部的安全距离,然后通过@sup[……]

继续阅读

2021-04-01 Comments (0)
阅读全文

什么是PAC文件

什么是PAC文件?

PAC文件是在使用代理服务器的时候,告诉浏览器该如何选择的一个配置文件。所以PAC文件又称为代理自动配置文件。

PAC文件实质上是JavaScript代码。

如何编写PAC文件

下面是一个最简单的PAC文件代码:

function FindProxyForURL(url[......]

继续阅读

2019-03-06 Comments (0)
阅读全文

JavaSript模块规范:AMD规范与CMD规范介绍

JavaSript模块化

在了解AMD,CMD规范前,还是需要先来简单地了解下什么是模块化,模块化开发?

模块化是指在解决某一个复杂问题或者一系列的杂糅问题时,依照一种分类的思维把问题进行系统性的分解以之处理。模块化是一种处理复杂系统分解为代码结构更合理,可维护性更高的可管理的模块的方式。可以想[……]

继续阅读

2018-08-23 Comments (0)
阅读全文

JavaScript的api设计原则

前言

本篇博文来自一次公司内部的前端分享,从多个方面讨论了在设计接口时遵循的原则,总共包含了七个大块。系卤煮自己总结的一些经验和教训。本篇博文同时也参考了其他一些文章,相关地址会在后面贴出来。很难做到详尽充实,如果有好的建议或者不对的地方,还望不吝赐教斧正。

一 接口的流畅性

好的接口是流畅易[……]

继续阅读

2018-08-23 Comments (1)
阅读全文

移动端抓包及web调试指南

本文包括:

  1. 抓包(截获网络请求)
    • 在Windows上使用Fiddle抓包
    • 在Mac上使用Charles抓包
  2. 页面调试:
    • 在Windows上调试iOS
    • 在Windows上调试Android
    • 在Mac上调试iOS
    • 在Mac上调试Android

本文旨在解决的问题包括:

  1. 在电脑上通[……]

    继续阅读

2018-05-09 Comments (0)
阅读全文

JavaScript需要特别注意的地方

1 转换

parseInt(0.000001)  // 0
parseInt(0.0000001)  // 1

'5' == 5  // true

2 null

typeof null  // "object"

null == undefined  // true

10 + null[......]

继续阅读

2018-04-23 Comments (0)
阅读全文

JavaScript截取字符串slice()、substr()、substring()的区别

共同点

第二个参数都可以省略,省略以后都是截取到字符串最后。

区别

第一个参数
  • substring() 不能为负数
  • substr() 可以是负数,是负数从尾部开始计算
  • slice() 可以是负数,是负数从尾部开始计算
第二个参数
  • substring() 不能为负数,终点的位置,需要[……]

    继续阅读

2018-04-17 Comments (0)
阅读全文

一个典型的闭包方案,取for循环中i的值

有个网友问了个问题,如下的html,为什么每次输出都是5,而不是点击每个p,就alert出对应的1,2,3,4,5。

<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; chars[......]

继续阅读

2018-02-23 Comments (0)
阅读全文

前端图片懒加载

https://mp.weixin.qq.com/s/JYglEGYN9tnGpDg7ARPx7w
http://gitlab.66xue.com/xdf-fe/LoadOnDemand[……]

继续阅读

2018-01-11 Comments (0)
阅读全文

JavaScript 工具库 ez.js

2017-09-26 Comments (0)
阅读全文

前端扩展插件

模拟数据

Easy Mock
野狗

JavaScript 交互

waypoints 滚动到某元素触发某事件

JavaScript UI工具

autosize 自动调整textarea输入框大小
clipboardjs 剪切板
jQuery custom content scroller 滚[……]

继续阅读

2017-09-16 Comments (0)
阅读全文

IE下载保存base64文件

如果一个超链接的链接地址是一个base64的代码,如下:

<a href="[......]

继续阅读

2017-08-31 Comments (2)
阅读全文

前端跨域方法总结

什么是 AJAX 跨域

端口不同,域名(包括子域,层级)不同,协议不同。

前端跨域

  1. 超链接、重定向、表单提交
  2. 资源引入<link>、<script>、<img>、<frame>等dom标签,还有样式中background:url()、@font[……]

    继续阅读

2017-08-14 Comments (0)
阅读全文

JavaScript匿名函数的写法

// 最常用的两种写法
(function(){ /* code */ }()); // 老道推荐写法
(function(){ /* code */ })(); // 当然这种也可以

// 括号和JS的一些操作符(如 = && || , 等)可以在函数表达式和函数声明上消除歧义[......]

继续阅读

2017-07-26 Comments (0)
阅读全文

stopPropagation(),preventDefault()和return false

阅读本文之前你最好了解JavaScript在浏览器中 事件冒泡事件捕获 两个概念。

因为HTML结构中存在着父、子节点的事件冒泡,以及浏览器默认动作,所以我们使用 JavaScript 时为了达到预期效果经常需要阻止事件和动作执行. 一般我们会用到三种方法, 分别是 stopPropagat[……]

继续阅读

2017-07-13 Comments (0)
阅读全文

JavaScript 几个需要注意的知识点

1 for in
for in 循环可以取得对象所有可枚举的属性,包括继承的属性。
Object.keys() 不能取得继承的属性,而 Object.getOwnPropertyNames() 可以替代 for in。

2 使用 new 操作符创建对象,如果构造函数内部有 return 语[……]

继续阅读

2017-05-18 Comments (0)
阅读全文

JavaScript操作Checkbox,以及获取选中状态

基于jQuery

1 选中状态

1.1 选中的元素
[js]
$(‘input[type=checkbox]:checked’)
$(‘input:checkbox:checked’)
[/js]

2.2 是否选中
[js]
$(‘input:checkbox’).is[……]

继续阅读

2017-04-14 Comments (0)
阅读全文

如何开发Chrome扩展程序

Chrome扩展程序为谷歌浏览器提供了丰富的扩展功能。
那如果开发一个谷歌Chrome浏览器的扩展程序呢?

首先,我正在翻译谷歌浏览器开发者平台的中文版(Chrome开发文档中文版),现在已经翻译完成了扩展程序开发最基本的几篇内容:

  1. 什么是Chrome扩展程序?
  2. Chrome扩展程序概[……]

    继续阅读

2017-04-12 Comments (0)
阅读全文

Object.defineProperty()默认值是false的误解

在JavaScript中,通过Object.defineProperty()方法来定义对象的属性,详情可以参照《JavaScript高级程序设计》第3版第6章6.1.1属性类型(第139页)。

书中指出:

“注意在调用Object.defineProperty()方法时,如果不指定, c[……]

继续阅读

2017-03-29 Comments (1)
阅读全文

TOP