服务端渲染对于刚接触vue的新手来说,并不是那么友好,虽然已有官方SSR中文文档。但是对于一个已经开发完毕的vue项目去接SSR无论是从工作量还是技术角度来说,都是一种挑战。
2、预渲染方式
在构建时(buildtime)简单地生成针对特定路由的静态HTML文件。优点是设置预渲染更简单,并可以将您的前端作为一个完全静态的站点。如果您使用webpack,您可以使用prerender-spa-plugin轻松地添加预渲染。它已经被Vue应用程序广泛测试。
VUE前端开发遇到的问题
大家好,我是王我。 随着春节的结束,各个行业也普遍开始了上班的节奏, 不过本人17号才上班。为什么?因为长得帅的都上班比较晚。 每到新年结束,又迎来了一批招聘者与面试者,我来说说作为一年工作经验应该知道的面试题。 HTML篇 1.doctype是什么?有哪些类型? 2.input有哪些新类型?简要说明其8用法。 3.HTML5有哪些新特性,移除了哪些元素?如何处理HTML5新标签的浏览器兼容问题?如何区分HTML和HTML5? 4.bootstrap响应式的原理是什么? 5.多移动终端页面适配是如何实现的? CSS篇 1.如何实现两列布局,左边自适应,右边固定宽度? 2.用CSS画一个三角形 3.CSS实现字体大写 4.display有哪些常用的属性值?分别是什么意思? 5.position为absolute,relative,fixed的定点位置 6.用三种方法清除浮动 7.请介绍一下margin塌陷问题 js篇 1.什么是事件冒泡和捕获?如何阻止事件冒泡?(分别用原生和jquery实现) 2.js创建对象,至少使用三种方法 3.简述一下事件穿透以及解决办法 4.用三种方式判断变量类型是否是数组 5.如何实现对象的拷贝? 6.什么是闭包?闭包的优缺点。 7.简述一下ajax请求的过程。 8.简述一下new一个人构造函数的人过程。 9.为什么会有跨域?是怎么解决跨域问题的?简述一下原理。 10.js原始数据类型有哪些? 11.学一个函数,判断一个变量是否是字符串 12.typeof有哪些结果? 13.剪头函数和普通函数有什么区别? 14.请用三种方法实现数组去重 15.href和src有什么区别? jquery篇 1.attr()和prop()有什么区别? 2.on和bind有什么区别?js动态添加的dom元素是通过on还是bind? 3.touch和click有什么区别? 4.window.onload和jquery的ready有什么区别? vue篇 1.简述一下vue的生命周期及其特点 2.vue双向绑定的原理是什么? 3.vue的特点有哪些?和jquery有什么区别? 4.父子组件之间传递数据的方法 5.子组件如何共享数据? 6.一般有什么工具进行数据交互? 7.webpack的原理是什么? 8.简述一下$nextTick的用法 浏览器篇 1.cookie、sessionStorage、localStorage的区别是什么? 2.有用过浏览器缓存吗?简述一下基本的缓存机制 网络篇 1.http和https之间的区别 2.从服务器的安全考虑,是使用get请求还是post请求? 3.URL请求的过程有哪些? 项目经验篇 1.项目中遇到的最大挑战以及解决办法 2.常见的网页优化有哪些? 作为一个面试一年以内工作经验的前端程序员来说,以上的问题能够倒答如流月薪6k应该不成问题啦。这些面试题也是我在很多面试中感觉经常被问到的题目。 希望大家年后找工作能够顺顺利利, 千万不要跟我一样哦,只有帅气就一无所有了。 大家好,我是王我,中国最帅的前端程序员。 前几次都是各种培训公司,各种忽悠就不提了,说说后面4次面试的经历。 第一次是面一个小公司,不过他们好像没有厉害的前端,来面我的是个后端,一来没有问我关于js的知识,直接问我以前做过什么,有没有经验,我本人不会吹牛,简历也没怎么包装,就是自己把自学的知识和做的几个小demo弄在上面,也用github挂在页面上了,不过他根本不点开看,也不问,问我会不会vue,我当时对框架还不了解,他就说他们需要能直接上手开始写的,所以我第一个就直接挂了。 第二次面试是一个国企,这个问了很多问题,都很基础,js数据类型,数组操作,事件,大概就是高程的前面几章看看就差不多都能答到,然后因为他们主要用jq,所以问了很多jq的操作,关于节点的,动画的,我看锋利的jq大概看了3遍,也练过多次,所以我答的很熟。然后问了些布局方面的,bootstrap我了解过,又看过css3,所以这方面也没啥问题,最后在现场做了个题目,主要就是布局然后通过ajax呈现数据。后面听介绍我面试的说面试官比较满意,说我jq很熟,一面就过了。可惜后面电话面试不知怎么回事可能表现的不够自信,虽然没问技术,但是我没啥自信,把没项目经验什么的也不知怎么就一五一十交代了,估计因为这个挂掉了。 第三次没问问题,直接就是一套题开做,我在那做了一个多小时。题目就是按照要求一步一步做一个页面出来,我也搞忘了我当时卡在哪个地方了,坐在那得时候就是做不出来,没有设计图,要根据他的描述自己找个设计图然后做,我第一次遇到这个有点懵,虽然当时没做出来,不过回来我自己花了几个小时把它做了。所以这个也是凉了。 第四个问的比较多,数据类型,数组操作,跨域,ajax,闭包,原型链,继承,深拷贝,浅拷贝,模块amd cmd,基本都是问的js。然后问了html5的新特性 css3 的新特性,遇到过什么浏览器的兼容性问题,怎么解决的,以后想往什么方面发展。这个时候我已经会点vue了,照着做了个小demo,不过后来知道公司用的angularjs,面试官也没看我做的,问也没问。。以前听网上说要带上自己的项目去面试感觉没起多大效果。 最后总结下如果面的比较初级的岗位,应该主要问js,原型链,继承,闭包,深浅拷贝,ajax,跨域,然后js的基础知识,对了还有apply和call也问了,html5的新特性了解下就行。主要就是看你js掌握的程度,如果稍微要求高一点的,暂时还没面过,等以后面过在来回答 1. cookie session 的用途和区别,以及有效期 1、cookie数据存放在客户的浏览器上,session数据放在服务器上。 2、cookie不是很安全,别人可以分析存放在本地的COOKIE并进行COOKIE欺骗 考虑到安全应当使用session。 3、session会在一定时间内保存在服务器上。当访问增多,会比较占用你服务器的性能 考虑到减轻服务器性能方面,应当使用COOKIE。 4、单个cookie保存的数据不能超过4K,很多浏览器都限制一个站点最多保存20个cookie。 2. vue的数据绑定原理,mvvm与mvc的区别 MVVM: m:model数据模型层 v:view视图层 vm:ViewModelvue中采用的是mvvm模式,这是从mvc衍生过来的MVVM让视图与viewmodel直接的关系特别的紧密,就是为了解决mvc反馈不及时的问题 图片说明一下: 说到MVVM就要说一下双向绑定和数据劫持的原理, MVC: m:model数据模型层 v:view视图层 c:controller控制器 原理: c层需要控制model层的数据在view层进行显示 MVC两种方式,图片说明: mvvm与mvc最大的区别: MVVM实现了view与model的自动同步,也就是model属性改变的时候, 我们不需要再自己手动操作dom元素去改变view的显示,而是改变属性后该属性对应的view层会自动改变。 不懂得可以复制链接查看: https://www.pianshen.com/article/3716256399/ 3. storage 的区别 sessionStorage localStorage localStorage 的生命周期是永久性的。假若使用localStorage存储数据,即使关闭浏览器,也不会让数据消失,除非主动的去删除数据,使用的方法如上所示。localStorage有length属性 sessionStorage 的生命周期是在浏览器关闭前。也就是说,在整个浏览器未关闭前,其数据一直都是存在的。sessionStorage也有length属性,其基本的判断和使用方法和localStorage的使用是一致的 4.v-model双向数据原理 有一个文本框 通过v-bind绑定了value属性 值为myname 是我们在vue实例中定义的属性传统我们获取文本框值方法 可能通过getElementById找到文本框 然后获取其value属性但是vue中直接通过v-bind绑定了value属性 所以不需要像之前那样获取值所以在后面的按钮中获取name值 直接获取vue实例对象data里面的myname属性即可 【数据为尊 ----数据映射到浏览器 如果数据v-model后修改(肯定input)然后到数据在有数据映射到浏览器页面 ----映射关系统称】 5.keepAlive用过吗?什么作用? 缓存路由组件 使用的是vue的一个组件,参考vue的官方文档 使用这个东西可以保证我们在切换组件的时候,原来显示的组件不被销毁 -----【保障组件的数据不会被切换路由而销毁数据】 Home是对应的组件对象的名字,不是路由的名字 6.多维数组拍平 数组拍平也称数组扁平化,就是将数组里面的数组打开,最后合并为一个数组 一红六种方法吧…… 了解的请看: https://www.cnblogs.com/guan-shan/p/10165737.html 7.跨域的原因 解决方案 跨域是指一个域下的文档或脚本试图去请求另一个域下的资源,这里跨域是广义的。 这样就可以说同源策略----协议---端口---域名 原生的src和href可以解决跨域 代理可以解决 请求头也可以携带浏览器提示的也可以解决 一般都是后端解决跨域问题 【别的需要了解看下方链接】 https://blog.csdn.net/qq_41604383/article/details/100770100 8.uniApp兼容问题 § 如果你使用cli创建项目(即项目根目录是package.json),不管用什么ide,即便是用HBuilderX,切记cli项目的编译器是在项目下的,HBuilderX不管怎么升级都不会影响编译器版本。你需要手动npm update来升级编译器。以及如果你想要安装less、scss等预编译器,也需要自己npm安装在项目下,而不是在HBuilderX的插件管理里安装。 § 如果你使用离线打包,请注意HBuilderX升级后,真机运行基座和云打包对应引擎跟随HBuilderX升级,而你的sdk需要手动升级。sdk的版本升级一般滞后HBuilderX正式版升级一两天。 § 如果你使用自定义基座,之前制作的自定义基座是不会跟随HBuilderX升级的,升级HBuilderX后你应该重新制作新版自定义基座。 § 如果你使用wgt升级,新版HBuilderX编译的wgt,运行到之前的runtime上,一定要先测试好,看有没有兼容性问题。如果有问题,就不要wgt升级,整包升级。 § 考虑到向下兼容,uni-app编译器在升级为新的自定义组件模式后,同时保留了对老编译模式的向下兼容。在HBuilderX alpha版中,App端一定会使用新编译器,不理会manifest配置。在HBuilderX 正式版中,新创建的项目会使用新编译器,老项目不会强制使用,而是开发者自己在manifest里配置开启。 § 如果你使用其他ide开发uni-app,会经常因为拼错单词而运行失败,因为经过webpack编译一道,很多错误反应的不够直观,排错时间很长,不如从开始就依赖有良好提示的HBuilderX,避免敲错单词。 § 云打包的引擎版本说明HBuilderX Alpha,只有1套云打包机,不管你的HBuilderX alpha版本多少,对应的打包机一定是最新的alpha版的客户端引擎。HBuilderX正式版,有2套打包机,一个是最新正式版,一个是次新正式版。中间的紧急更新版本没有独立打包机。举个例子:HBuilderX 有1.8.0、1.8.1、1.8.2、1.9.0、1.9.1这几个正式版。那么当前可用的打包机有1.9.1和1.8.2这2台。(即每个大版本的最后一个版本)除了这2个HBuilderX版本外,其他版本的云打包都指向最新的1.9.1版对应的打包机。(即只保留2个大版本的云打包机) 【详情请看】 https://ask.dcloud.net.cn/article/35845 一、HTML HTML书写规范 H5新增标签 HTML渲染过程 二、CSS css盒子模型概念 css弹性布局概念 三、JavaScript 事件模型 DOM2级事件模型 闭包 原型链 四、移动Web开发 常见的布局方案 移动端前端常见的触摸相关事件touch、tap、swipe等整理 移动端前端手势事件 移动端页面渲染优化 GPU渲染 GPU核心渲染过程 五、调试 常用的调试工具 Chrome控制台调试js使用 移动端测试 六、HTTP网络知识 常见的HTTP状态码 不同请求类型的区别 WEB缓存方案 —————————— 牛客网(www.nowcoder.com) - 专业IT笔试面试备考平台 - 最全C JAVA前端等互联网技术求职题库 - 全面提升IT编程能力 - 程序员交友圣地 分享了一些Web前端的面试题,限时一小时,你看看自己能够答出多少道! 放心,这些面试题都是一些非常基础的知识,只要你在平时认真听课、学习了,那么这些面试题肯定不会难道你。 建议:虽然没有人监督你,但还是希望你不要去寻找答案,脱离百度,拿起纸笔,你试一下自己究竟能够答出个什么水平!有没有真本领?答案尽在这些面试题里!你准备好了吗?OK!计时开始! 一、HTML常见题目 01、Doctype作用?严格模式与混杂模式如何区分?它们有何意义? 02、HTML5为什么只需要写? 03、行内元素有哪些?块级元素有哪些?空(void)元素有那些? 04、页面导入样式时,使用link和@import有什么区别? 05、介绍一下你对浏览器内核的理解? 06、常见的浏览器内核有哪些? 07、html5有哪些新特性、移除了那些元素?如何处理HTML5新标签的浏览器兼容问题? 08、如何区分HTML和HTML5? 09、简述一下你对HTML语义化的理解? 10、HTML5的离线储存怎么使用,工作原理能不能解释一下? 二、CSS类的题目 01、介绍一下标准的CSS的盒子模型?与低版本IE的盒子模型有什么不同的? 02、CSS选择符有哪些?哪些属性可以继承? 03、CSS优先级算法如何计算? 04、CSS3新增伪类有那些? 05、如何居中p?如何居中一个浮动元素?如何让绝对定位的p居中? 06、display有哪些值?说明他们的作用。 07、position的值relative和absolute定位原点是? 08、CSS3有哪些新特性? 09、请解释一下CSS3的Flexbox(弹性盒布局模型),以及适用场景? 10、用纯CSS创建一个三角形的原理是什么? 三、Java类的题目 01、介绍Java的基本数据类型。 02、说说写Java的基本规范? 03、Java原型,原型链?有什么特点? 04、Java有几种类型的值?(堆:原始数据类型和栈:引用数据类型),你能画一下他们的内存图吗? 05、Java如何实现继承? 06、Java创建对象的几种方式? 07、Java作用链域? 08、谈谈This对象的理解。 09、eval是做什么的? 10、什么是window对象?什么是document对象? OK,一小时到了,这个时间可不算短了,那么这些面试题你答出了几道呢?你写的答案正确了吗?现在你可以去翻看答案了。 如果你答出了绝大多数的或者是全部的题,并且答案也正确了,那么恭喜你…… 你这时心里是不是有点小窃喜,认为自己有能力拿高薪了?虽然我也很想这么告诉你,但事实上这只能表明你的基础扎实,毕竟这只是一些非常基础的面试题。骚年~继续努力吧! 如果你只答出了小部分或者答出了大部分题但答案不正确,那么我只想说:“骚年,你的水平还差的远呢。”连这么基础的题你都打不出来,还想拿高薪?回去再练一段时间吧! 扎实的基础是你拿高薪的重要武器,如果你连基础都不扎实,那么想要攻克“高薪”这个厚实的堡垒,那只是痴人说梦罢了。 1.前端框架类问题,问你会不会用vue react啊 2.语言类,问你一些JavaScript语言的问题 3.项目经验,让你讲讲做过的项目,遇到的问题和解决之道
VUE前端开发常见问题
这次给大家带来Vue在前端开发中需要注意什么,Vue在前端开发的注意事项有哪些,下面就是实战案例,一起来看一下。
基于Vue官方风格指南整理
一、强制1. 组件名为多个单词
组件名应该始终是多个单词的,根组件 App 除外。
正例:
export default {name: TodoItem,// ...
}
反例:
export default {name: Todo,// ...
}2. 组件数据
组件的 data 必须是一个函数。
当在组件中使用 data 属性的时候 (除了 new Vue 外的任何地方),它的值必须是返回一个对象的函数。
正例:
// In a .vue file
export default {data () {return {foo: bar}}
}
// 在一个 Vue 的根实例上直接使用对象是可以的,
// 因为只存在一个这样的实例。
new Vue({data: {foo: bar}
})反例:
export default {data: {foo: bar}
}3. Prop定义
Prop 定义应该尽量详细。
在你提交的代码中,prop 的定义应该尽量详细,至少需要指定其类型。
正例:
props: {status: String
}
// 更好的做法!
props: {status: {type: String,required: true,validator: function (value) {return [syncing,synced,version-conflict,error].indexOf(value) !== -1}}
}反例:
// 这样做只有开发原型系统时可以接受
props: [status]4. 为v-for设置键值
总是用 key 配合 v-for。
在组件上_总是_必须用 key 配合 v-for,以便维护内部组件及其子树的状态。甚至在元素上维护可预测的行为,比如动画中的对象固化 (object constancy),也是一种好的做法。
正例:
{{ todo.text }}
反例:
{{ todo.text }}
5.避免 v-if 和 v-for 用在一起
永远不要把 v-if 和 v-for 同时用在同一个元素上。
一般我们在两种常见的情况下会倾向于这样做:
为了过滤一个列表中的项目 (比如 v-for="user in users" v-if="user.isActive")。在这种情形下,请将 users 替换为一个计算属性 (比如 activeUsers),让其返回过滤后的列表。
为了避免渲染本应该被隐藏的列表 (比如 v-for="user in users" v-if="shouldShowUsers")。这种情形下,请将 v-if 移动至容器元素上 (比如 ul, ol)。
正例:
{{ user.name }}
反例:
{{ user.name }}
6. 为组件样式设置作用域
对于应用来说,顶级 App 组件和布局组件中的样式可以是全局的,但是其它所有组件都应该是有作用域的。
这条规则只和单文件组件有关。你不一定要使用 scoped 特性。设置作用域也可以通过 CSS Modules,那是一个基于 class 的类似 BEM 的策略,当然你也可以使用其它的库或约定。
不管怎样,对于组件库,我们应该更倾向于选用基于 class 的策略而不是 scoped 特性。
这让覆写内部样式更容易:使用了常人可理解的 class 名称且没有太高的选择器优先级,而且不太会导致冲突。
正例:
X.c-Button {border: none;border-radius: 2px;
}
.c-Button--close {background-color: red;
}
反例:
X.btn-close {background-color: red;
}X.button {border: none;border-radius: 2px;
}
.button-close {background-color: red;
}
二、强烈推荐(增强可读性)1. 组件文件
只要有能够拼接文件的构建系统,就把每个组件单独分成文件。
当你需要编辑一个组件或查阅一个组件的用法时,可以更快速的找到它。
正例:
components/
|- TodoList.vue
|- TodoItem.vue反例:
V
ue.component(TodoList, {// ...
})
Vue.component(TodoItem, {// ...
})2. 单文件组件文件的大小写
单文件组件的文件名应该要么始终是单词大写开头 (PascalCase)
正例:
components/
|- MyComponent.vue反例:
components/
|- myComponent.vue
|- mycomponent.vue3. 基础组件名
应用特定样式和约定的基础组件 (也就是展示类的、无逻辑的或无状态的组件) 应该全部以一个特定的前缀开头,比如 Base、App 或 V。
正例:
components/
|- BaseButton.vue
|- BaseTable.vue
|- BaseIcon.vue反例:
components/
|- MyButton.vue
|- VueTable.vue
|- Icon.vue4. 单例组件名
只应该拥有单个活跃实例的组件应该以 The 前缀命名,以示其唯一性。
这不意味着组件只可用于一个单页面,而是每个页面只使用一次。这些组件永远不接受任何 prop,因为它们是为你的应用定制的,而不是它们在你的应用中的上下文。如果你发现有必要添加 prop,那就表明这实际上是一个可复用的组件,只是目前在每个页面里只使用一次。
正例:
components/
|- TheHeading.vue
|- TheSidebar.vue反例:
components/
|- Heading.vue
|- MySidebar.vue5. 紧密耦合的组件名
和父组件紧密耦合的子组件应该以父组件名作为前缀命名。
如果一个组件只在某个父组件的场景下有意义,这层关系应该体现在其名字上。因为编辑器通常会按字母顺序组织文件,所以这样做可以把相关联的文件排在一起。
正例:
components/
|- TodoList.vue
|- TodoListItem.vue
|- TodoListItemButton.vue
components/
|- SearchSidebar.vue
|- SearchSidebarNavigation.vue反例:
components/
|- SearchSidebar.vue
|- NavigationForSearchSidebar.vue6. 组件名中的单词顺序
组件名应该以高级别的 (通常是一般化描述的) 单词开头,以描述性的修饰词结尾。
正例:
components/
|- SearchButtonClear.vue
|- SearchButtonRun.vue
|- SearchInputQuery.vue
|- SearchInputExcludeGlob.vue
|- SettingsCheckboxTerms.vue
|- SettingsCheckboxLaunchOnStartup.vue反例:
components/
|- ClearSearchButton.vue
|- ExcludeFromSearchInput.vue
|- LaunchOnStartupCheckbox.vue
|- RunSearchButton.vue
|- SearchInput.vue
|- TermsCheckbox.vue7. 模板中的组件名大小写
总是 PascalCase 的
正例:反例:8. 完整单词的组件名
组件名应该倾向于完整单词而不是缩写。
正例:
components/
|- StudentDashboardSettings.vue
|- UserProfileOptions.vue反例:
components/
|- SdSettings.vue
|- UProfOpts.vue9. 多个特性的元素
多个特性的元素应该分多行撰写,每个特性一行。
正例:反例:10. 模板中简单的表达式
组件模板应该只包含简单的表达式,复杂的表达式则应该重构为计算属性或方法。
复杂表达式会让你的模板变得不那么声明式。我们应该尽量描述应该出现的是什么,而非如何计算那个值。而且计算属性和方法使得代码可以重用。
正例:{{ normalizedFullName }}
// 复杂表达式已经移入一个计算属性
computed: {normalizedFullName: function () {return this.fullName.split( ).map(function (word) {return word[0].toUpperCase() word.slice(1)}).join( )}
}反例:
{{fullName.split( ).map(function (word) {return word[0].toUpperCase() word.slice(1)}).join( )
}}11. 简单的计算属性
正例:
computed: {basePrice: function () {return this.manufactureCost / (1 - this.profitMargin)},discount: function () {return this.basePrice * (this.discountPercent || 0)},finalPrice: function () {return this.basePrice - this.discount}
}反例:
computed: {price: function () {var basePrice = this.manufactureCost / (1 - this.profitMargin)return (basePrice -basePrice * (this.discountPercent || 0))}
}12. 带引号的特性值
非空 HTML 特性值应该始终带引号 (单引号或双引号,选你 JS 里不用的那个)。
在 HTML 中不带空格的特性值是可以没有引号的,但这样做常常导致带空格的特征值被回避,导致其可读性变差。
正例:
反例:
13. 指令缩写
都用指令缩写 (用 : 表示 v-bind: 和用 @ 表示 v-on:)
正例:
反例:
三、推荐1. 单文件组件的顶级元素的顺序
单文件组件应该总是让、 和 标签的顺序保持一致。且 要放在因为另外两个标签至少要有一个。
正例:.../* ... */四、谨慎使用 (有潜在危险的模式)1. 没有在 v-if/v-if-else/v-else 中使用 key
如果一组 v-if v-else 的元素类型相同,最好使用 key (比如两个 元素)。
正例:
错误:{{ error }}{{ results }}反例:错误:{{ error }}{{ results }}
2. scoped 中的元素选择器
元素选择器应该避免在 scoped 中出现。
在 scoped 样式中,类选择器比元素选择器更好,因为大量使用元素选择器是很慢的。
正例:
X.btn-close {background-color: red;
}
反例:
Xbutton {background-color: red;
}
3. 隐性的父子组件通信
应该优先通过 prop 和事件进行父子组件之间的通信,而不是 this.$parent 或改变 prop。
正例:
Vue.component(TodoItem, {props: {todo: {type: Object,required: true}},template: ``
})反例:
Vue.component(TodoItem, {props: {todo: {type: Object,required: true}},methods: {removeTodo () {var vm = thisvm.$parent.todos = vm.$parent.todos.filter(function (todo) {return todo.id !== vm.todo.id})}},template: `{{ todo.text }}X`
})4. 非 Flux 的全局状态管理
应该优先通过 Vuex 管理全局状态,而不是通过 this.$root 或一个全局事件总线。
正例:
// store/modules/todos.js
export default {state: {list: []},mutations: {REMOVE_TODO (state, todoId) {state.list = state.list.filter(todo => todo.id !== todoId)}},actions: {rem