前端进阶之旅前端进阶之旅
基础篇
进阶篇
高频篇
精选篇
手写篇
原理篇
面经篇
自检篇
每日一题
  • 综合
    • 综合题型
    • 其他问题
    • 设计模式
    • 思维导图
    • 学习路线
  • 前端基础
    • HTTP
    • 浏览器
    • 计算机基础
  • 进阶学习
    • NPM工作流
    • Docker
    • Canvas
    • Node学习指南
    • 前端综合文章
  • 其他
    • Handbook
    • 职场话题
    • CSS可视化
小程序题库
公众号动态
博客动态
开发者导航
基础篇
进阶篇
高频篇
精选篇
手写篇
原理篇
面经篇
自检篇
每日一题
  • 综合
    • 综合题型
    • 其他问题
    • 设计模式
    • 思维导图
    • 学习路线
  • 前端基础
    • HTTP
    • 浏览器
    • 计算机基础
  • 进阶学习
    • NPM工作流
    • Docker
    • Canvas
    • Node学习指南
    • 前端综合文章
  • 其他
    • Handbook
    • 职场话题
    • CSS可视化
小程序题库
公众号动态
博客动态
开发者导航
  • JavaScript Part 1

    • Ajax总结篇
    • Canvas 绘制八大行星
    • Canvas 绘制动画时钟
    • Canvas 绘制粒子动画背景
    • DOM编程之API学习总结篇
    • JS 中的 call、apply、bind 方法
    • JS 中的事件绑定、事件监听、事件委托
    • JS常用的内置函数整理
    • JS继承的几种方法总结
    • JS计算字符串所占字节数
    • JavaScript-DOM事件
    • JavaScript事件机制
    • JavaScript代码片段100个
      • 100个JavaScript代码片段
        • 实现字符串长度截取
        • 获取域名主机
        • 清除空格
        • 替换全部
        • 转义html标签
        • 生JavaScript还原html标签
        • 时间日期格式转换
        • 判断是否为数字类型
        • 设置cookie值
        • 获取cookie值
        • 加入收藏夹
        • 设为首页
        • 判断IE6
        • 加载样式文件
        • 返回脚本内容
        • 清除脚本内容
        • 动态加载脚本文件
        • 返回按ID检索的元素对象
        • 返回浏览器版本内容
        • 元素显示的通用方法
        • 中有insertBefore方法,可惜却没有insertAfter方法?用如下函数实现
        • 中兼容浏览器绑定元素事件
        • 光标停在文字的后面,文本框获得焦点时调用
        • 检验URL链接是否有效
        • 格式化CSS样式代码
        • 压缩CSS样式代码
        • 获取当前路径
        • IP转成整型
        • 整型解析为IP地址
        • 实现checkbox全选与全不选
        • 判断是否移动设备
        • 判断是否移动设备访问
        • 判断是否苹果移动设备访问
        • 判断是否安卓移动设备访问
        • 判断是否Touch屏幕
        • 判断是否在安卓上的谷歌浏览器
        • 判断是否打开视窗
        • 获取移动设备初始化大小
        • 获取移动设备最大化大小
        • 获取移动设备屏幕宽度
        • 完美判断是否为网址
        • 根据样式名称检索元素对象
        • 判断是否以某个字符串开头
        • 判断是否以某个字符串结束
        • 返回IE浏览器的版本号
        • 获取页面高度
        • 获取页面scrollLeft
        • 获取页面可视宽度
        • 获取页面宽度
        • 获取页面scrollTop
        • 获取页面可视高度
        • 跨浏览器添加事件
        • 跨浏览器删除事件
        • 去掉url前缀
        • 随机数时间戳
        • 全角半角转换,iCase: 0全到半,1半到全,其他不转化
        • 确认是否键盘有效输入值
        • 获取网页被卷去的位置
        • 另一种正则日期格式化函数+调用方法
        • 时间个性化输出功能
        • 解决offsetX兼容性问题
        • 常用的正则表达式
        • 实现返回顶部的通用方法
        • 获得URL中GET参数值
        • 实现全选通用方法
        • 实现全部取消选择通用方法
        • 实现打开一个窗体通用方法
        • 判断是否为客户端设备
        • 获取单选按钮的值
        • 获取复选框的值
        • 判断是否为邮箱
        • 判断是否有列表中的危险字符
        • 判断字符串是否大于规定的长度
        • 判断字符串是为网址不区分大小写
        • 判断字符串是否为小数
        • 判断字符串是否为整数
        • 判断字符串是否为浮点数
        • 判断字符是否为A-Za-z英文字母
        • 判断字符串是否邮政编码
        • 判断字符是否空NULL
        • 用正则表达式提取页面代码中所有网址
        • 用正则表达式清除相同的数组(低效率)
        • 用正则表达式清除相同的数组(高效率)
        • 用正则表达式按字母排序,对每行进行数组排序
        • 字符串反序
        • 用正则表达式清除html代码中的脚本
        • 动态执行JavaScript脚本
        • 动态执行VBScript脚本
        • 实现金额大写转换函数
        • 常用的正则表达式大收集
        • 实现窗体改变事件resize的操作
        • 用正则清除空格分左右
        • 判断变量是否空值
        • 实现base64解码
        • 实现utf8解码
        • 获取窗体可见范围的宽与高
        • 判断IE版本号
        • 获取浏览器版本号
        • 半角转换为全角函数
        • 全角转换为半角函数
    • JavaScript作用域分析总结
    • JavaScript原型链回顾
    • JavaScript原生数组及高阶函数
    • JavaScript及jQuery中的各种宽高属性图解
    • JavaScript启示录阅读笔录
    • JavaScript对象
    • JavaScript工程项目的一系列最佳实践
    • JavaScript常用API合集
    • JavaScript常用的代码片段
    • JavaScript数组、字符串、对象常用方法
    • JavaScript数组方法总结篇
    • JavaScript深浅拷贝
    • JavaScript继承的几种方式
    • JavaScript词法分析和作用域闭包
    • JavaScript运动框架之速度时间版本
    • JavaScript运行机制Event Loop
    • JavaScript防抖节流原理
    • Javascript中的复制粘贴功能
    • Javascript常用方法函数收集
    • Javascript数组详解
    • OOP之原型与原型链
    • OOP之类与对象
    • OOP之面向对象
    • Object.defineProperty详解
    • V8源码浅析JS数组常见方法
    • arguments详解
    • await 在 forEach 中不生效解决方案
    • iframe+表单跨域提交POST请求
    • javascript 下常用的字符串操作
    • javascript常用积累
    • javascript笔记总结篇
    • parsetInt parsetFloat与eval isNaN用法
    • 业务中处理数据结构常用的JS方法
    • 作用域
    • 你真的掌握变量和类型了吗
    • 前后端分离之数据Mock
    • 原型与原型链
    • 原生JS与jQuery操作DOM对比
    • 原生JS补给(上)
    • 如何写出一个惊艳面试官的深拷贝
    • 带你填一些JS容易出错的坑
    • 彻底弄懂 JavaScript 执行机制
    • 执行上下文 执行栈
    • 梳理常用的正则表达式
    • 正则回顾总结
    • 正则基础知识
    • 正则完整篇
    • 正则表达式
    • 浅析JSON stringify
    • 浅析Promise原理
    • 浅谈JavaScript中的异步处理
    • 浅谈闭包
    • 深拷贝 vs 浅拷贝
    • 编写可维护的JavaScript
    • 聊一聊typeof instanceof 实现原理.
    • 聊一聊闭包
    • 高阶函数map reduce filter
  • JavaScript Part 2

  • CSS

  • HTML

  • Jquery

  • ES6

  • 小程序

  • Vue

  • React

  • 深入React

  • React Native

  • NodeJS

  • Angular

  • TypeScript

  • Webpack

  • 浏览器

  • 移动端

  • 前端工程化

  • Electron

  • HTTP

  • Nginx

  • Linux

  • 数据结构与算法

  • LeetCode算法题

  • 综合

完整面试题地址:
作者:程序员poetry
扫码关注作者公众号:「前端进阶之旅」 每天分享技术干货
前端进阶之旅公众号二维码

# 100个JavaScript代码片段

# 实现字符串长度截取

function cutstr(str, len) {
        var temp;
        var icount = 0;
        var patrn = /[^\x00-\xff]/;
        var strre = "";
        for (var i = 0; i < str.length; i++) {
            if (icount < len - 1) {
                temp = str.substr(i, 1);
                if (patrn.exec(temp) == null) {
                    icount = icount + 1
                } else {
                    icount = icount + 2
                }
                strre += temp
            } else {
                break
            }
        }
        return strre + "..."
    }
@前端进阶之旅: 代码已经复制到剪贴板

# 获取域名主机

function getHost(url) {
        var host = "null";
        if(typeof url == "undefined"|| null == url) {
            url = window.location.href;
        }
        var regex = /^\w+\:\/\/([^\/]*).*/;
        var match = url.match(regex);
        if(typeof match != "undefined" && null != match) {
            host = match[1];
        }
        return host;
}
@前端进阶之旅: 代码已经复制到剪贴板

# 清除空格

 String.prototype.trim = function() {
         var reExtraSpace = /^\s*(.*?)\s+$/;
         return this.replace(reExtraSpace, "$1
fe
基础篇
进阶篇
高频篇
精选篇
手写篇
原理篇
面经篇
自检篇
每日一题
  • 综合
    • 综合题型
    • 其他问题
    • 设计模式
    • 思维导图
    • 学习路线
  • 前端基础
    • HTTP
    • 浏览器
    • 计算机基础
  • 进阶学习
    • NPM工作流
    • Docker
    • Canvas
    • Node学习指南
    • 前端综合文章
  • 其他
    • Handbook
    • 职场话题
    • CSS可视化
小程序题库
公众号动态
博客动态
开发者导航
  • JavaScript Part 1

    • Ajax总结篇
    • Canvas 绘制八大行星
    • Canvas 绘制动画时钟
    • Canvas 绘制粒子动画背景
    • DOM编程之API学习总结篇
    • JS 中的 call、apply、bind 方法
    • JS 中的事件绑定、事件监听、事件委托
    • JS常用的内置函数整理
    • JS继承的几种方法总结
    • JS计算字符串所占字节数
    • JavaScript-DOM事件
    • JavaScript事件机制
    • JavaScript代码片段100个
      • 100个JavaScript代码片段
        • 实现字符串长度截取
        • 获取域名主机
        • 清除空格
        • 替换全部
        • 转义html标签
        • 生JavaScript还原html标签
        • 时间日期格式转换
        • 判断是否为数字类型
        • 设置cookie值
        • 获取cookie值
        • 加入收藏夹
        • 设为首页
        • 判断IE6
        • 加载样式文件
        • 返回脚本内容
        • 清除脚本内容
        • 动态加载脚本文件
        • 返回按ID检索的元素对象
        • 返回浏览器版本内容
        • 元素显示的通用方法
        • 中有insertBefore方法,可惜却没有insertAfter方法?用如下函数实现
        • 中兼容浏览器绑定元素事件
        • 光标停在文字的后面,文本框获得焦点时调用
        • 检验URL链接是否有效
        • 格式化CSS样式代码
        • 压缩CSS样式代码
        • 获取当前路径
        • IP转成整型
        • 整型解析为IP地址
        • 实现checkbox全选与全不选
        • 判断是否移动设备
        • 判断是否移动设备访问
        • 判断是否苹果移动设备访问
        • 判断是否安卓移动设备访问
        • 判断是否Touch屏幕
        • 判断是否在安卓上的谷歌浏览器
        • 判断是否打开视窗
        • 获取移动设备初始化大小
        • 获取移动设备最大化大小
        • 获取移动设备屏幕宽度
        • 完美判断是否为网址
        • 根据样式名称检索元素对象
        • 判断是否以某个字符串开头
        • 判断是否以某个字符串结束
        • 返回IE浏览器的版本号
        • 获取页面高度
        • 获取页面scrollLeft
        • 获取页面可视宽度
        • 获取页面宽度
        • 获取页面scrollTop
        • 获取页面可视高度
        • 跨浏览器添加事件
        • 跨浏览器删除事件
        • 去掉url前缀
        • 随机数时间戳
        • 全角半角转换,iCase: 0全到半,1半到全,其他不转化
        • 确认是否键盘有效输入值
        • 获取网页被卷去的位置
        • 另一种正则日期格式化函数+调用方法
        • 时间个性化输出功能
        • 解决offsetX兼容性问题
        • 常用的正则表达式
        • 实现返回顶部的通用方法
        • 获得URL中GET参数值
        • 实现全选通用方法
        • 实现全部取消选择通用方法
        • 实现打开一个窗体通用方法
        • 判断是否为客户端设备
        • 获取单选按钮的值
        • 获取复选框的值
        • 判断是否为邮箱
        • 判断是否有列表中的危险字符
        • 判断字符串是否大于规定的长度
        • 判断字符串是为网址不区分大小写
        • 判断字符串是否为小数
        • 判断字符串是否为整数
        • 判断字符串是否为浮点数
        • 判断字符是否为A-Za-z英文字母
        • 判断字符串是否邮政编码
        • 判断字符是否空NULL
        • 用正则表达式提取页面代码中所有网址
        • 用正则表达式清除相同的数组(低效率)
        • 用正则表达式清除相同的数组(高效率)
        • 用正则表达式按字母排序,对每行进行数组排序
        • 字符串反序
        • 用正则表达式清除html代码中的脚本
        • 动态执行JavaScript脚本
        • 动态执行VBScript脚本
        • 实现金额大写转换函数
        • 常用的正则表达式大收集
        • 实现窗体改变事件resize的操作
        • 用正则清除空格分左右
        • 判断变量是否空值
        • 实现base64解码
        • 实现utf8解码
        • 获取窗体可见范围的宽与高
        • 判断IE版本号
        • 获取浏览器版本号
        • 半角转换为全角函数
        • 全角转换为半角函数
    • JavaScript作用域分析总结
    • JavaScript原型链回顾
    • JavaScript原生数组及高阶函数
    • JavaScript及jQuery中的各种宽高属性图解
    • JavaScript启示录阅读笔录
    • JavaScript对象
    • JavaScript工程项目的一系列最佳实践
    • JavaScript常用API合集
    • JavaScript常用的代码片段
    • JavaScript数组、字符串、对象常用方法
    • JavaScript数组方法总结篇
    • JavaScript深浅拷贝
    • JavaScript继承的几种方式
    • JavaScript词法分析和作用域闭包
    • JavaScript运动框架之速度时间版本
    • JavaScript运行机制Event Loop
    • JavaScript防抖节流原理
    • Javascript中的复制粘贴功能
    • Javascript常用方法函数收集
    • Javascript数组详解
    • OOP之原型与原型链
    • OOP之类与对象
    • OOP之面向对象
    • Object.defineProperty详解
    • V8源码浅析JS数组常见方法
    • arguments详解
    • await 在 forEach 中不生效解决方案
    • iframe+表单跨域提交POST请求
    • javascript 下常用的字符串操作
    • javascript常用积累
    • javascript笔记总结篇
    • parsetInt parsetFloat与eval isNaN用法
    • 业务中处理数据结构常用的JS方法
    • 作用域
    • 你真的掌握变量和类型了吗
    • 前后端分离之数据Mock
    • 原型与原型链
    • 原生JS与jQuery操作DOM对比
    • 原生JS补给(上)
    • 如何写出一个惊艳面试官的深拷贝
    • 带你填一些JS容易出错的坑
    • 彻底弄懂 JavaScript 执行机制
    • 执行上下文 执行栈
    • 梳理常用的正则表达式
    • 正则回顾总结
    • 正则基础知识
    • 正则完整篇
    • 正则表达式
    • 浅析JSON stringify
    • 浅析Promise原理
    • 浅谈JavaScript中的异步处理
    • 浅谈闭包
    • 深拷贝 vs 浅拷贝
    • 编写可维护的JavaScript
    • 聊一聊typeof instanceof 实现原理.
    • 聊一聊闭包
    • 高阶函数map reduce filter
  • JavaScript Part 2

  • CSS

  • HTML

  • Jquery

  • ES6

  • 小程序

  • Vue

  • React

  • 深入React

  • React Native

  • NodeJS

  • Angular

  • TypeScript

  • Webpack

  • 浏览器

  • 移动端

  • 前端工程化

  • Electron

  • HTTP

  • Nginx

  • Linux

  • 数据结构与算法

  • LeetCode算法题

  • 综合