【web前端】前段时间的面题整理(1)
这是我的试题答案整理,可能有多种答案。我也就写了一两种。在慢慢整合中
第一题
用js实现随机选取10-100之间的10个数字,存入一个数组,去重后求和(保证这10个数字不能出现重复)
要求:去重不能使用Set
请完善下面的题目
function sumOfRandomDistinctTenNumbers(){
// todo
}
我的答案
分析:Math.random()*90是0到90随机数,+10是10到100随机数,Math.floor是取整。
filter 进行数组去重。
function sumOfRandomDistinctTenNumbers(){
let arr=[]//空数组
for(let i=0;i<10;i++){
arr[i]=Math.floor(Math.random()*90+10);//10-100的随机数
}
// console.log(arr)//10个
//数组去重
arr=arr.filter((n,i)=>{
return arr.indexOf(n)===i
})
num=arr.reduce((x,y)=>{
return x+y
})
console.log(arr,num)//打印
}
sumOfRandomDistinctTenNumbers()
起初,我不并不清楚Set这种方式,所以稍微看了下Set去重的方式,确实更简单。我们来看看
const quchong=arr=>[...new Set(arr)];
console.log(quchong([1,2,3,2,3,2,true,false,true,'','',[1,2,3,2]]))//[1,2,3,true,false,'',[1,2,3,2]]
不过,可以看到,一级数组已经去重了,二级数组还是没有去重的。不过一般二级数组还是应该遍历去重。
第二题
给定一个编码字符,按编码规则进行解码,输出字符串。编码规则是count[letter],将letter的内容count次输出,count是0或正整数,letter是区分大小写的纯字母,支持嵌套形式。
示例:
请完善下面的题目
const s1 = '10[a]2[bc]'; decodeString(s); // 返回'aaaaaaaaaabcbc'
const s2 = '2[3[a]2[bc]]'; decodeString(s); // 返回 'aaabcbcaaabcbc' //请完善下面的方法
function decodeString() {
// todo
}
我的答案
分析:match正则表达式取出所有匹配“整数[字符串]”的集合,map遍历,将前面匹配的内容进行运算替换,递归调用该函数进行下一次匹配替换。直到替换完为止。
//解读字符串
function decodeString(str){
//若不存在[ 返回当前字符串
if(str.indexOf('[')==-1){
return str
}
//正则表示 整数[字符串] 并提取出所有匹配字符串
let list=str.match(/(\d+)(\[([a-z]|[A-Z])+\])/ig)
list.map((l)=>{
//l为所有匹配字符串
let s=l.indexOf('[')
let e=l.indexOf(']')
let num=l.substring(0,s)//次数
let char=l.substring(s+1,e)//字符
let charStr=''
for(let i=0;i<Number(num);i++){
charStr+=char
}
str=str.replace(l,charStr)//替换原字符串的匹配内容成新字符串
})
return decodeString(str);//再次重新解读新字符串
}
console.log(decodeString('2[10[a]2[bc3[d]]]qq'))
第三题
基于 React 框架写一个列表,列表每项有一个删除该项的功能。
请完善下面的题目
'use strict';
import React, { Component } from 'react';
// 单项
class Item extends Component {
state = {
}
constructor(props) {
super(props);
}
// 补全删除功能
render() {
return (
<div>
{/* 在此完成功能 */}
</div>
)
}
}
// 列表
class List extends Component {
state = {
list: new Array(10).fill('')
}
constructor(props) {
super(props);
}
render() {
return (
<div>
<h1>List</h1>
{/* 完成渲染功能 */}
</div>
)
}
}
我的答案
分析:List组件中有多个Item组件,点击删除自身。子组件回调父组件方法
'use strict';
import React, { Component } from 'react';
// 单项
class Item extends Component{
state={}
constructor(props){
super(props)
console.log(props.data)
}
//删除 回调父组件函数
delete(){
this.props.delete()
}
render(){
return (
<div>
<span>内容{this.props.data.li}{this.props.data.i}</span>
<a href='javascript:;' onClick={this.delete.bind(this)}>删除</a>
</div>
)
}
}
//列表
class List extends Component{
state={
//10个元素的空字符串数组
list:new Array(10).fill('')
}
constructor(props){
super(props)
}
//删除数组指定位置元素
delete(i){
let {list}=this.state
delete list[i]
this.setState({list:list})
}
render(){
return (
<div>
<h1>List</h1>
{
this.state.list.map((li,i)=>{
return (
<Item key={i} data={{li:li,i:i}} delete={this.delete.bind(this,i)} />
)
})
}
</div>
)
}
}
效果图:

【web前端】前段时间的面题整理(1)的更多相关文章
- 腾讯2013笔试题—web前端笔试题 (老题练手)
问题描述(web前端开发附加题1): 编写一个javascript的函数把url解析为与页面的javascript.location对象相似的实体对象,如:url :'http://www.qq.co ...
- [转] Web前端开发工程师常用技术网站整理
1.常用工具相关 有道云笔记 http://note.youdao.com/signIn/index.html 36镇-最好用的共享收藏夹 http://www.36zhen.com/ 浏览器同步测试 ...
- Web前端开发工程师常用技术网站整理
1.常用工具相关 有道云笔记 http://note.youdao.com/signIn/index.html 36镇-最好用的共享收藏夹 http://www.36zhen.com/ 浏览器同步测试 ...
- web前端教程《每日一题》(1-99)完结
第1期(2016年4月6日): (1)js中关闭当前窗口的方法是:window.close(); 第2期(2016年4月7日): (1)js中使字符串中的字符变为小写的方法是:toLowerCase方 ...
- 收集的WEB前端程序员需要的网站整理
前端学习资源实在是又多又广,在这样的一个知识的海洋里,我们像一块海绵一样吸收,想要快速提高效率,平时的总结不可缺少,以下总结了一些,排版自我感觉良好,推送出来. 一.插件类网站 jQuery插件库:h ...
- WEB前端程序员需要的网站整理
前端学习资源实在是又多又广,在这样的一个知识的海洋里,我们像一块海绵一样吸收,想要快速提高效率,平时的总结不可缺少,以下总结了一些,排版自我感觉良好,推送出来. 一.插件类网站 jQuery插件库:h ...
- 资深阿里程序员一一为你解刨Web前端知识体系结构,付出与收获成正比!
只要接触过前端,都会指导web前端的知识主要由三部分组成:分别为静态html,样式css,动态javascript(简称js)这三大部分组成.其三部分组成的一个体系的复杂程度不亚于其他一门技术的复杂程 ...
- 面试WEB前端如何才能通过?
从事web前端工作七年时间,因为一直是非常热爱编程的,从小就有兴趣,大学就是学计算机的,技术应该比一般同龄的都要好一些,今天我想给大家讲述一下,目前想要做web前端开发,面试成功应该如何去学习,要具备 ...
- 【编码题篇】收集整理来自网络上的一些常见的 经典前端、H5面试题 Web前端开发面试题
编写一个方法 求一个字符串的字节长度假设:一个英文字符占用一个字节,一个中文字符占用两个字节 function GetBytes(str){ var len = str.length; var byt ...
随机推荐
- ARM工作模式寻址
用户模式(User) usr 快速中断模式(FIQ) fiq 普通终端模式(IRQ) irq 保护模式(Supervisor) svc 数据访问终止模式(Abo ...
- AD使用adsi 组件 获取域信息
// testadsi.cpp : 定义控制台应用程序的入口点.// #include "stdafx.h"#include "windows.h"#inclu ...
- thinkPHP模型定义
批量新增 ArrayAccess类的属性当做数组访问 插入语句 这段代码说明,User继承的Model类的isupdate属性默认是isupdate,而User::get(1)把这一字段属性更新为tr ...
- pyqt5--动画
动画类别继承结构图 天子骄龙
- 【NOIP2016提高A组模拟9.14】数列编辑器
题目 分析 比赛上,没有注意到询问只询问光标前面,于是只打了个暴力. 因为询问只询问光标前面,首先,当光标向后每移动到一个位置,顺便将这个位置的前缀和,和最大前缀和求出来. 总之,模拟 #includ ...
- 【leetcode】689. Maximum Sum of 3 Non-Overlapping Subarrays
题目如下: In a given array nums of positive integers, find three non-overlapping subarrays with maximum ...
- DevOps之持续集成SonarQube代码质量扫描
一.SonarQube介绍 SonarQube是一个用于代码质量检测管理的开放平台,可以集成不同的检测工具,代码分析工具,以及持续集成工具.SonarQube 并不是简单地把不同的代码检查 ...
- 14. ClustrixDB 高可用性的最佳实践
本文档详细介绍了最大化ClustrixDB上运行的应用程序正常运行时间的最佳实践.这涵盖了广泛的主题,从环境需求到变更管理程序,所有这些最终都会影响应用程序的可用性.其中许多是您可能已经熟悉的标准最佳 ...
- linux-网络管理-6
Hub 集线器 物理层设备 多端口中继器,不记忆MAC地址 以太网桥 OSI第二层数据链路层 扩展了网络带宽 分割了网络冲突域,使网络冲突被限制在最小的范围内 交换机作为更加智能的交换设备,能够提供更 ...
- UVa 1602 Lattice Animals (STL && 生成n连块 && 无方向形状判重)
题意 : 给定一个 w * h 的 矩阵,在矩阵中找不同n个连通块的个数(旋转,翻转,平移算作一种) 分析 : 这题的关键点有两个 ① 生成n连块并且存储起来(因为题目是多测试用例,如果每一次都重新生 ...