首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

年薪30万的前端面试题,你能答对几道?|附答案

c:父元素设置 position:relative 和 left:50%,子元素设置 position:relative 和 left:50%; 垂直居中设置: 使用position:absolute...id选择器( # myid) 类选择器(.myclassname) 标签选择器(div, h1, p) 相邻选择器(h1 + p) 子选择器(ul > li) 后代选择器(li a) 通配符选择器( *...如何解释json数据 使用eval parse,鉴于安全性考虑 使用parse更靠谱; 7.事件委托是什么 让利用事件冒泡的原理,让自己的所触发的事件,让他的父元素代替执行!...看起来,就像是Ruby/Rails当年的样子。 2.你有哪些性能优化的方法?...向前端优化指的是,在不影响功能和体验的情况下,能在浏览器执行的不要在服务端执行,能在缓存服务器上直接返回的不要到应用服务器,程序能直接取得的结果不要到外部取得,本机内能取得的数据不要到远程取,内存能取到的不要到磁盘取

5.6K60
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    总结Web应用中常用的各种Cache

    框架默认使用Rack::ETag middleware,它会自动给无etag的response加上etag,但是和fresh_when相比,自动etag能够节省的只是客户端时间,服务器端还是一样会执行所有的代码...动态请求静态文件化 在rails请求完成以后,将结果保存成静态文件,后续请求就会直接由nginx提供静态文件内容,用after_filter来实现一下: class CategoriesController...('public', 'categories') endend Rails 4之前,处理这种生成静态文件缓存可以用内置的caches_page, rails 4之后变成了一个独立gem actionpack-page_caching...rails内置了query cache (https://github.com/rails/rails/blob/master/activerecord/lib/active_record/connection_adapters...(fetch),以及额外的关系定义。

    4.7K40

    开发项目管理工具redmine 原

    为什么使用Redmine? 基于上面的多种特性,在项目管理工作中,如任务分配、任务跟踪、项目权限管理等等带来很大的便捷性,使得工作进度、质量更加可控。...在此使用rvm管理ruby,rvm 是一个命令行工具,可以提供一个便捷的多版本 Ruby 环境的管理和切换,如果你打算学习 Ruby / Rails, RVM 是必不可少的工具之一。...r=54309 Note: 数据库相关配置写入/etc/my.cnf下,避免服务重启后配置被还原。...数据初始化: $ RAILS_ENV=production bundle exec rake redmine:load_default_data ## 该过程会以交互形式让用户选择语言环境变量,也可以在执行该命令时直接指定环境变量...=production ; 冲突: 如果出现“找不到“.bundle/ ”文件”的错误信息,原因是执行命令时所在路径不对,切换至 /usr/local/src/redmine 重新执行即可!

    10.1K40

    慢的不是 Ruby,而是你的数据库

    更实际的情况是:几年前我为了修复一个 N+1 查询而加入的 User.active.includes(:roles) 动态地选择它认为你需要的内容。...sorting-by-un-indexed-field 示例揭示了 Rails 与数据库的耦合如何使其许多性能问题成为数据库问题。 根据我的经验,Rails 中的性能问题总是: N+1 个查询。...因为只有当你已经有了以前没有使用过的索引时,才需要为这种新的查询方式优化数据库(这意味着它以前优化得很差)。...另一种情况是当你重用现有索引时,在这种情况下,你很可能应该重构以将查询转移到单一责任(例如,命名范围)。...我采用的一些经验法则是: 在可以避免的情况下,不要使用数据库。这总是比我想象的更频繁。我不需要将世界上 195 个国家存储在数据库中,并在显示国家下拉列表时加入。只需硬编码或在启动时输入配置读取。

    15130

    如何在CentOS 6.5上使用Unicorn和Nginx部署Rails应用程序

    在这篇教程中,我们将介绍如何组装多层部署安装来托管基于Rails的Ruby Web应用程序。对于这种安排,我们将使用在Nginx后台运行的功能强大,灵活且非常成功的Unicorn应用服务器。...谈到功能,应该注意的是,有一些流行的服务器可供选择,每个服务器提供不同的功能:一些专注于简单性,一些专注于速度,以及一些可能配置全覆盖选项以满足复杂生产需求的一切。...准备部署服务器 在本节中,我们将执行以下步骤: 更新操作系统 获取必要的基本部署工具 安装Ruby,Rails和库 安装应用程序(即Unicorn)和HTTP服务器(Nginx) 更新和准备操作系统 运行以下命令以更新...执行以下命令以使Rails创建名为“my_app”的新应用程序: # Create a sample Rails application cd /var mkdir www cd www rails...在本教程中,我们将重点介绍关键元素,从头开始创建一个文件,Unicorn将在启动应用程序服务器守护进程时使用该文件。

    4.1K20

    Redis特性和应用场景

    秒内容如超过10个key被修改,则发起快照保存 save 60 10000 下面介绍详细的快照保存过程 1.redis调用fork,现在有了子进程和父进程。...父进程继续处理client请求,子进程负责将内存内容写入到临时文件。...由于os的写时复制机制(copy on write)父子进程会共享相同的物理页面,当父进程处理写请求时os会为父进程要修改的页面创建副本,而不是写共享的页面。...save操作是在主线程中保存快照的,由于redis是用一个主线程来处理所有client的请求,这种方式会阻塞所有client请求。所以不推荐使用。...当子进程把快照内容写入已命令方式写到临时文件中后,子进程发信号通知父进程。然后父进程把缓存的写命令也写入到临时文件。 5.

    1.4K70

    Redis特性和应用场景

    #300秒内容如超过10个key被修改,则发起快照保存 save 60 10000 下面介绍详细的快照保存过程 1.redis调用fork,现在有了子进程和父进程。...父进程继续处理client请求,子进程负责将内存内容写入到临时文件。...由于os的写时复制机制(copy on write)父子进程会共享相同的物理页面,当父进程处理写请求时os会为父进程要修改的页面创建副本,而不是写共享的页面。...save操作是在主线程中保存快照的,由于redis是用一个主线程来处理所有client的请求,这种方式会阻塞所有client请求。所以不推荐使用。...当子进程把快照内容写入已命令方式写到临时文件中后,子进程发信号通知父进程。然后父进程把缓存的写命令也写入到临时文件。 5.

    1.9K70

    如何在Ubuntu 14.04上使用Puma和Nginx部署Rails应用程序

    介绍 当您准备部署Ruby on Rails应用程序时,需要考虑许多有效的设置。...创建Rails应用程序 理想情况下,您已经拥有了要部署的Rails应用程序。如果是这种情况,您可以跳过本节,并在跟随时进行适当的替换。...将生产密码和机密保存在应用程序代码库之外被认为是最佳实践,因为如果您使用的是分布式版本控制系统(如Git),它们很容易暴露出来。接下来我们将讨论如何使用环境变量设置数据库身份验证。 保存并退出。...保存并退出。这会将Puma配置为应用程序的位置,以及其套接字,日志和PID的位置。随意修改文件,或添加您需要的任何其他选项。...例如: /home/deploy/appname 保存并退出。 现在,您的应用程序配置为在启动时通过Upstart启动。这意味着即使在重新启动服务器后,您的应用程序也会启动。

    5.4K10

    不愧是字节,面个实习也满头大汗!

    子进程从fork调用的位置开始执行,父进程和子进程在fork调用之后的代码处继续执行。 资源继承:子进程继承了父进程的大部分资源,包括打开的文件、文件描述符、信号处理器等。...也就是说,数据库每轮抽查时,会随机选择 20 个 key 判断是否过期。...执行 bgsave 命令的时候,会通过 fork() 创建子进程,此时子进程和父进程是共享同一片内存数据的,因为创建子进程的时候,会复制父进程的页表,但是页表指向的物理内存还是一个,此时如果主线程执行读操作...防止索引失效:用上了索引并不意味着查询的时候会使用到索引,所以我们心里要清楚有哪些情况会导致索引失效,从而避免写出索引失效的查询语句,否则这样的查询效率是很低的。...Using temporary:使了用临时表保存中间结果,MySQL 在对查询结果排序时使用临时表,常见于排序 order by 和分组查询 group by。效率低,要避免这种问题的出现。

    30111

    彻底理解 MySQL 的索引机制,终于不再因为 MySQL 优化而被面试官鄙视了

    二叉树 特征:要保证父节点大于左子结点,小于右子节点。 极端情况下会产生如下所示的树: ? 2....所有的数据都保存在叶子节点上 所有的叶子节点包含了所有的元素的信息,且所有的叶子节点根据元素的大小从小到大组成一个链表 根节点以及所有的中间节点同时在于子节点,在子节点中是最大(或最小)元素 下图是一个...B+ 树)—> 那为什么选择 B+ 树 —–> 因为 B+ 树节点不保存全部数据,因此在一页(一个节点)上能够存更加多的索引数据,让树的高度更低。...如何进行慢查询优化? 首先我们来看下一个 SQL 的执行过程: ? 接下来为大家介绍一个慢查询优化神器——explain 命令。...总结 本文从数据结构层面深入剖析了索引,解释为什么在众多数据结构中选择了 B+ 树,以及如何创建高性能的索引,并例举了许多大家平时开发中时常遇到的 MySQL 优化案例,希望能给大家带来帮助。

    2.2K21

    Ruby 应用容器封装踩坑记录(Lobsters)

    写在前面 首先回答为什么要考虑对 Ruby 应用进行容器化封装。...第一回合:尝试升级 Ruby 2.4.0 第一回合在更新镜像 Ruby 依赖时,报了版本不兼容的错误。...具体情况表现为,在应用启动时会报告类似下面的警告: /lobsters/.bundle/ruby/2.7.0/gems/activerecord-5.2.4.1/lib/active_record/migration.rb...虽然我们在容器中首次进行安装,不需要清理缓存,但是考虑到官方镜像潜在的 tricks,还是选择设置安装时不从缓存中读取内容稳妥些。...或许你会疑问,为什么不考虑在最初就禁用这些依赖呢?因为后续我们考虑开发环境也在容器中进行,所以需要保障带有开发依赖的配置也能够被正确初始化。

    7.4K10

    Ruby 应用容器封装踩坑记录(Lobsters)

    写在前面 首先回答为什么要考虑对 Ruby 应用进行容器化封装。...第一回合:尝试升级 Ruby 2.4.0 第一回合在更新镜像 Ruby 依赖时,报了版本不兼容的错误。...具体情况表现为,在应用启动时会报告类似下面的警告: /lobsters/.bundle/ruby/2.7.0/gems/activerecord-5.2.4.1/lib/active_record/migration.rb...虽然我们在容器中首次进行安装,不需要清理缓存,但是考虑到官方镜像潜在的 tricks,还是选择设置安装时不从缓存中读取内容稳妥些。...或许你会疑问,为什么不考虑在最初就禁用这些依赖呢?因为后续我们考虑开发环境也在容器中进行,所以需要保障带有开发依赖的配置也能够被正确初始化。

    4.9K00

    常见公司MySQL面试题全集

    但是,在并发的情况下,多个事务共同操作一个数据库时,可能会产生脏读、不可重复读、幻读问题 脏读:当前事务(A)中可以读到其他事务(B)未提交的数据(脏数据),这种现象是脏读。...所有的叶子结点中包含了全部元素的信息,及指向含这些元素记录的指针,且叶子结点本身依关键字的大小自小而大顺序链接。 每一个父节点都出现在子节点中,是子节点元素中是最大(或最小)元素。...InnoDB不保存表的具体行数,执行select count(*) from table时需要全表扫描。...而MyISAM用一个变量保存了整个表的行数,执行上述语句时只需要读出该变量即可,速度很快(注意不能加有任何WHERE条件); 那么为什么InnoDB没有了这个变量呢?...如果是子查询,id的序号会递增,id值越大优先级越高,越先被执行 3.id如果相同,可以认为是一组,从上往下顺序执行;在所有组中,id值越大,优先级越高,越先执行 select_type 查询中每个

    39430

    57道常被问的CSS面试题及答案汇总,帮你查漏补缺

    important 比内联优先级高 4、CSS优先级算法如何计算? 元素选择符:1 class选择符:10 id选择符:100 元素标签:1000 !...选择属于其父元素的唯一子元素 p:nth-child(2) 选择属于其父元素的第二个子元素 :enabled :disabled 表单控件的禁用状态。...BFC是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素。 计算BFC的高度时,浮动元素也会参与计算。...避免过度约束 避免后代选择符 避免链式选择符 使用紧凑的语法 避免不必要的命名空间 避免不必要的重复 最好使用表示语义的名字。一个好的类名应该是描述他是什么而不是像什么 避免!...36、CSS属性overflow属性定义溢出元素内容区的内容会如何处理? 参数是scroll时候,必会出现滚动条。 参数是auto时候,子元素内容大于父元素时出现滚动条。

    2.7K31

    57道CSS常问面试题及答案汇总

    important 比内联优先级高 4、CSS优先级算法如何计算? 元素选择符:1 class选择符:10 id选择符:100 元素标签:1000 !...选择属于其父元素的唯一子元素 p:nth-child(2) 选择属于其父元素的第二个子元素 :enabled :disabled 表单控件的禁用状态。...BFC是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素。 计算BFC的高度时,浮动元素也会参与计算。...避免过度约束 避免后代选择符 避免链式选择符 使用紧凑的语法 避免不必要的命名空间 避免不必要的重复 最好使用表示语义的名字。一个好的类名应该是描述他是什么而不是像什么 避免!...36、CSS属性overflow属性定义溢出元素内容区的内容会如何处理? 参数是scroll时候,必会出现滚动条。 参数是auto时候,子元素内容大于父元素时出现滚动条。

    2K10

    2023年超全前端面试题-背完稳稳拿offer(欢迎补充)

    :display:grid 子元素:grid-template-columns:100px auto 20px CSS选择器 标签选择器 ID选择器 类选择器 组选择器 通配符选择器 后代选择器 子元素选择器...闭包用途: 能够访问函数定义时所在的词法作用域(阻止其被回收) 私有化变量 模拟块级作用域 创建模块 闭包缺点:会导致函数的变量一直保存在内存中,过多的闭包可能会导致内存泄漏 原型、原型链(高频) 原型...因为事件在冒泡过程中会上传到父节点,并且父节点可以通过事件对象获取到目标节点,因此可以把子节点的监听函数定义在父节点上,由父节点的监听函数统一处理多个子元素的事件,这种方式称为事件代理。...在patchVnode(...)中,Vue会依据新旧两个Vnode对象是否拥有子节点children执行不同的DOM操作,当两个Vnode对象都有子节点时,会调用updateChildren(...)方法递归的对子节点进行...这种方案同时还可以减少图片总字节数,节省命名词汇量。 压缩图片: 图片占据资源极大,因此尽量避免使用多余的图片,使用时选择最合适的格式大小,然后使用智图压缩,同时在代码中用Srcset来按需显示。

    1.1K12

    redis入门指南读书笔记

    ,循环执行该命令,在不影响新元素加入的情况下,可以对元素进行循环检测 集合类型 集合类型存储不重复的元素,元素唯一,但无需,内部使用值为空的散列表实现,所以查询元素的时间复杂度为 ?...查询键的内部编码方式 object encoding 持久化 redis的高性能在于其数据保存于内存中,并且为了避免重启后丢失数据,提供了将数据同步到硬盘的方式,即持久化。...快照过程: redis使用fork函数复制当前进程(父进程)的副本(子进程) 父进程继续接收并处理客户端命令,子进程将内存中数据写入硬盘的临时文件中 子进程写入完毕,将该临时文件替换旧的rdb文件 fork...函数执行使用写时复制(copy on write)策略,父、子进程共享同一内存空间,当父进程执行写命令时,操作系统会将数据复制一份给子进程,避免子进程数据受影响。...为了避免这种单点故障的情况,需要将数据存储在多个服务器上,当一台服务器上redis更新数据时,通过复制功能将数据同步到其他服务器上。

    1K20

    来自大厂 10+ 前端面试题附答案(整理版)

    同理,在进行进程切换时,涉及当前执行进程 CPU 环境还有各种各样状态的保存及新调度进程状态的设置,而线程切换时只需保存和设置少量寄存器内容,开销较小。一个 tcp 连接能发几个 http 请求?...所以面试官更想听到 VDOM 想解决的问题以及为什么频繁的 DOM 操作会性能差。...这种方法的缺点是如果网站存在 XSS 漏洞的,那么这种方式会失效。同时这种方式不能做到子域名的隔离。...,那么按照 React 的树形结构进行分类的话,主要有以下三种情况:父组件向子组件通信,子组件向父组件通信以及平级的兄弟组件间互相通信。...在子与父的情况下 ,有两种方式,分别是回调函数与实例函数。回调函数,比如输入框向父级组件返回输入内容,按钮向父级组件传递点击事件等。

    54630
    领券