h5
底部输入框被键盘遮挡问题如果你遇到h5
页面这个问题,当输入框在最底部,点击软键盘后输入框会被遮挡,可以如下解决问题:
var getHeight = $(document).height();
$(window).resize(function(){
if($(document).height() < getHeight) {
$('#footer').css('position','static');
}else {
$('#footer').css('position','absolute');
}
});
$('html').one('touchstart',function(){
audio.play()
})
html, body, form, fieldset, p, div, h1, h2, h3, h4, h5, h6 {-webkit-text-size-adjust:none;}
页面分为3个部分:页面的顶部header
,底部footer
,中间部分(侧栏side
和主要部分main
)。
下面代码展示:
<body>
// 页面层容器
<div id="container">
// 页面头部
<div id="header"></div>
// 页面主体
<div id="main">>
// 侧边栏
<div id="side">
</div>
</div>
// 页面底部
<div id="footer"></div>
</div>
</body>
设计页面样式代码如下:
<style type="text/css">
body{
font: 12px 微软雅黑;
margin: 0px;
text-align: center;
background: #fff;
}
// 页面层容器
#container {
width: 100%;
}
#header {
width: 800px;
margin: 0 auto;
height: 100px;
background: #FFCC99;
}
#main {
width: 800px;
margin: 0 auto;
height: 400px;
}
#side {
float: left;
width: 20em;
background: red;
padding: 15px 0;
}
#foot {
width: 800px;
margin: 0 auto;
height: 50px;
background: #00ffff;
}
</style>
效果图如下:
MVVM
框架?MVVM
框架是一个Model-View-ViewModel
框架,其中ViewModel
连接模型Model
和视图View
。
在vue.js
中的MVVM
模式:
vue.js
是通过数据驱动的,vue.js
实例化对象将dom
和数据进行绑定,一旦绑定,dom
和数据将保持同步,每当数据发生变化,dom
也会随着变化;ViewModel
是Vue.js
的核心,它是Vue.js
的一个实例。Vue.js
会针对某个HTML
元素进行实例化,这个HTML
元素可以是body
,也可以是某个css
选择器所指代的元素。DOM Listeners
和Data Bindings
是实现双向绑定的关键。DOM Listeners
监听页面所有View
层中的DOM
元素,当发生变化时,Model
层的数据随之变化。Data Bindings
会监听Model
层的数据,当数据发生变化时,View
层的DOM
元素也随之变化。
active-class
是哪个组件的属性它是vue-router
模块的router-link
组件的属性
vue-router
的动态路由在静态路由名称前面添加冒号,如设置id
动态路由参数,为路由对象的path
属性设置/:id
在组件中,使用$router
对象的params.id
,如$route.params.id
vue-router
有哪几种导航的钩子有三种,第一种是全局导航钩子,router.beforeEach(to,from,next)
,作用是跳转前进行判断拦截;第二种是组件内的钩子;第三种是单独路由独享组件。
导航钩子又叫导航守卫,又分为全局钩子,单个路由独享钩子和组件级钩子。
全局钩子有beforeEach
,beforeResolve
,afterEach
,单个路由独享钩子有:beforeEnter
组件级钩子有:beforeRouteEnter
,beforeRouteUpdate
,beforeRouteLeave
:它们有以下参数:
to
表示即将要进入的目标路由对象;from
表示当前导航正要离开的路由;next
表示一定要用这个函数才能到达下一个路由,如果不用就会遭到拦截。
mint-ui
是什么mint-ui
它是基于Vue.js
的前端组件库,用npm
安装,然后通过import
导入样式和JavaScript
代码,vue.use(mintUi)
用于实现全局引入,import {Toast} from 'mint-ui'
用能于在单个组件局部引入
v-model
是什么v-model
是vue.js
的一条指令,实现数据的双向绑定
双向数据绑定的原理:
vue.js
使用es5
提供的属性特性功能,结合发布者-订阅者模式,通过Object.defineProperty()
为各个属性定义get,set
特性方法,在数据发送改变时给订阅者发布消息,触发相应的监听回调。
过程:a,对需要观察的数据对象进行递归遍历,包含子属性对象的属性,设置
set
和get
特性方法;当给这个对象的某个值赋值时,会触发绑定的set
特性方法,就能起到监听数据的变化。b,用compile
解析模板指令,将模板中的变量替换成数据,然后初始化渲染页面视图,并将每个指令对应的节点绑定更新函数,添加监听数据的订阅者,一旦数据有变动,就会收到通知,并更新视图。c,Watcher
订阅者是Observer
和Compile
之间通信的桥梁:在自身实例化时向属性订阅器dep
里面添加自己;自身必须有一个update()
方法;在dep.notice()
发布通知时,能调用自身的update()
方法,并触发Compile
中绑定的回调函数。d,MVVM
是数据绑定的入口,整合了Observer
,Compile
和Wathcher
三者,通过Observer
来监听自己的model
数据变化,通过Compile
来解析编译模板指令,最终利用Watcher
来搭起Observer
和Compile
之间的通信桥梁,达到数据变化通知视图更新的效果,利用视图交互,变化更新数据model
变更的双向绑定效果。
vue.js
中标签如何绑定事件第一种方式,使用v-on
;第二种方式,使用@
语法糖
vuex
是什么vuex
是vue.js
框架实现的状态管理系统。使用vuex
,要引入store
,并注入vue.js
组件中,在组件内部可以通过$store
访问store
对象;使用场景,在单页应用中,用于组件之间的通信,如音乐播放,登录状态管理,加入购物车等
vuex
可以说是一种开发模式或框架,它是对vue.js
框架数据层面的扩展,通过状态集中管理驱动组件的变化,应用的状态集中放在store
中,改变状态的方式是提交mutations
,这是个同步的事务,异步的逻辑应该封装在action
中。
vue
中说说你知道的自定义指令自定义指令两种:一种全局自定义指令,vue.js
对象提供了directive
方法,可以用来自定义指令,directive
方法接收两个参数,一个是指令名称,另一个是函数;第二种是局部自定义指令,通过组件的directives
属性定义。
vue.js
中常用的4种指令v-if
判断对象是否隐藏;v-for
循环渲染;v-bind
绑定一个属性;v-model
实现数据双向绑定
在v-if
循环中实现v-model
数据的双向绑定:
有时需要创建
input
,并用v-model
实现数据的双向绑定。此时可以为v-model
绑定数组的一个成语selected[$index]
,这样可以给不同的input
绑定不同的v-model
:
<div v-for="(item,index) in arrDa">
<input type="text" v-model="arrData[index]">
<h1>{{arrDa[index]}}</h1>
</div>
vue-router
是什么vue-router
是vue.js
的路由插件,(常用router-link
和router-view
)
vue.js
的生命周期共分8个阶段:
beforeCreate
在实例初始化之后,数据观测者
data observer
和event/watcher
事件配置之前调用
2 . created
在实例创建完成后立即调用,此时,实例已完成:观测者,属性和方法的运算,
watch/event
事件回调,挂载阶段还没开始,$el
属性目前不可见。
3 . beforeMount
在挂载开始之前调用,相关的
render
函数首次调用。
4 . mounted
el
被新创建的vm.$el
替换,并且在挂载到实例上之后再调用该钩。如果root
实例挂载了一个文档内元素,当调用mounted
时vm.$el
也在文档内。
5 . beforeUpdate
在数据更新时调用,发生在虚拟
dom
重新渲染和打补丁之前。
6 . updated
由于数据更改导致的虚拟
dom
重新渲染和打补丁,在这之后会调用该钩子。
7 . beforeDestroyed
在实例销毁之前调用,在这一步,实例仍然完全可用。
8 . destroyed
在vue.js
实例销毁后调用,vue.js
实例指示的所有东西都会解除绑定,所有的事件监听会被移除,所有的子实例也会被销毁。
如果使用组件的keep-alive
功能时,增加两个周期:
activated
在keep-alive
组件激活时调用;deactivated
在keep-alive
组件停用时调用。<keep-alive>
包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。<keep-alive>
是一个抽象组件,它自身不会渲染一个DOM
元素,也不会出现在父组件链中。
当在<keep-alive>
内切换组件时,它的activated
和deactivated
这两个生命周期钩子函数将会执行。
<keep-alive>
<component :is="view"></component>
</keep-alive>
增加一个周期钩子:ErrorCaptured
表示当捕获一个来自子孙组件的错误时调用。
vue
组件的作用过程组件可以提升整个项目的开发效率,能够把页面抽象成多个相对独立的模块,解决了传统项目开发中效率低,难维护,复用性等问题。
使用Vue.extend
方法创建一个组件,使用Vue.component
方法注册组件,子组件需要数据,可以在props
中接收数据,而子组件修改好数据后,想要把数据传递给父组件,可以使用emit
方法。
使用自定义组件:
在components
目录中新建组件文件,脚本一定要导出暴露的接口;导入需要用到的页面;将导入的组件注入vue.js
的子组件的components
属性中;在template
的视图中使用自定义组件。
创建组件
<div id="app">
<dada></dada>
</div>
<template id="demo">
<div>
<h1>{{msg}}</h1>
</div>
</template>
<script type="text/javascript">
// 定义组件类
var dada = Vue.extend({
template: '#demo',
data:function() {
return {
msg: 'dadaqianduan.cn'
}
}
})
// 注册组件
Vue.component('dada',dada);
// 定义Vue实例化对象
var app = new Vue({
el: '#app',
data: {}
})
</script>
vue-loader
是什么vue-loader
它是解析.vue
文件的一个加载器,将template/js/style
转换成javascript
模块;通过这个vue-loader
,javascript
可以写EMAScript6
语法,style
样式可以应用scss
或less
,template
可以添加jade
语法。。。
vue.cli
项目中的src
目录说明assets
文件夹存放静态资源;components
存放组件;router
定义路由相关的配置;view
是视图;app.vue
是一个应用主组件;main.js
是入口文件。vue.js
的template
编译的理解首先转化成AST
抽象语法树,Abstract Syntax Tree
,就是将源代码语法结构抽象成树状表现形式,然后通过render
函数进行渲染,并返回VNode
(Vue.js
的虚拟dom
节点)。
通过
compile
编译器把template
编译成AST
,compile
是createCompiler
的返回值,createCompiler
用来创建编译器,compile
还负责合并option
;AST
会经过generate
-将AST
转换成render function
字符串的过程-得到render
函数,render
的返回值是VNode
,VNode
是Vue.js
的虚拟DOM
节点,里面有标签名,子节点,文本等。
v-show
指令和v-if
指令的区别它们都是条件渲染指令,不同的是,v-show
的值无论是true
或false
元素都会存在于html
页面中,而v-if
的值为true
时,元素才会存在于html
页面中。
v-show
指令是通过修改元素的style
属性值实现的。
css
只在当前组件中起作用只需要在style
标签中添加scoped
属性,<style scoped></style>
vue.js
中如何实现路由嵌套路由嵌套会将其他组件渲染到该组件内,而不是使整个页面跳转到router-view
定义组件渲染的位置,要进行页面跳转,要将页面渲染到根组件内。首先实例化根组件,在根组件中定义组件渲染容器,然后,挂载路由,当切换路由时,将会切换整个页面。
new Vue({
el: '#dada',
router: router,
template: '<router-view></router-view>'
})
vue.js
中的ref
属性有什么作用可以直接访问组件内部的一些元素,定义属性可以在组件内部通过this.$refs
属性,,访问设置ref
属性的元素,这是一个原生的DOM
元素,要使用原生DOM API
操作它们。
vue.js
开发环境下调用接口,如何避免跨域在config/index.js
内对proxyTable
项进行如下配置:
proxyTable: {
'/api': {
target: 'http://xxx.com',
changeOrign: true,
pathRewrite: {
'^/api': ''
}
}
}
axios
是什么axios
是vue2.0
中用来替换vue-resource.js
插件的一个模块,是一个请求后台资源的模块
使用npm install axios
来安装axios
import Vue from 'vue'
import axios from 'axios';
Vue.prototype.$http = axios;
new Vue({
el: 'dada',
data: {
mag: ''
},
template: '<h1>{{msg}}</h1>',
created: function() {
this.$http.get('data.json').then(res=>{
this.msg = res.data.data
})
}
})
当调用axios.post('api/user')
时,表示发送post
异步请求。
sass
是什么sass
是一种css
预编译语言,用npm
安装加载程序;在webpack.config.js
中配置sass
加载程序
module: {
// 加载程序
loaders: {
// 加载scss
{
test: /\.scss$/,
loader: 'vue-style-loader!css-loader!sass-loader'
}
}
}
模板包含多个顶级元素;模板只包含普通文本;模板只包含其他组件,模板只包含一个元素指令,如vue-router
的<router-view>
;模板根节点有一个流程 控制指令,如v-if
或v-for
这些情况让实例有未知数量的顶级元素,模板将把它的DOM
内容当作片段。片段实例仍然会正确地渲染内容。不过,模板没有一个根节点,它的$el
指向一个锚节点,即一个空的文本节点。
在
vue2.0
中,组件的模板只允许有权只有一个根节点。
<div id="app">
<input type="text" v-model="inputValue">
<h1>{{showValue}}</h1>
</div>
var app = new Vue({
el: '#app',
data: {
inputValue: ''
},
computed: {
showValue: function() {
return this.inputValue || '请输入内容'
}
}
})
如果在初始化时没有定义数据,之后更新的数据是无法触发页面渲染更新的,这部分数据是丢失的数据,这种现象叫数据的丢失。
app.arr[0]=
app.arr.length
为了解决该问题,Vue.js
扩展了观察数组,为它添加了一个$set()
方法,用该方法修改的数组,能触发视图更新,检测数据变化。
app.$set(app.arr, 5, 500);
由于javascript
特性的限制,vue.js
不能检测到对象属性的添加或删除,因为Vue.js
在初始化时将数组转化为getter/setter
,所以属性必须在data
对象中定义,才能在初始化时让vue.js
转换它并让它响应。
var data = {
obj: {
a: 1
}
}
var app = new Vue({
el: '#app',
data: data
})
app.ojb.a = 10
app.obj.b = 20 // 不是响应的
data.obj.b = 20 // 不是响应的
如果需要在实例创建之后添加属性并且让它能够响应,使用$set
实例方法:
app.$set(app.obj, 'b', 200)
对于普通数据对象,可以全局方法Vue.set(object,key,value)
Vue.set(data.obj, 'b', 250)
vue.js
文件中的样式覆盖不生效的问题在style
上加上scoped
可以让样式私有化,只针对当前vue.js
文件中的代码有效,不会对别的文件中的代码造成影响,有时,引入第三方UI
,在vue.js
文件中进行样式覆盖不生效,大概是因为style
上的scoped
导致的。
可以将需要覆盖样式的这部分代码放到单独的css
文件中,在main.js
文件导入即可。
在开发中,常出现异步获取数据的情况,有时数据层次太深,如:
<text v-text="a.b.c.d"></text>
可以使用vm.$set
手动定义一层数据:vm.$set("dada", a.b.c.d)
vue.js
页面的闪烁在vue.js
有一个v-cloak
指令,该指令一直保持在元素上,直到关联实例结束编译。当和css
使用时,这个指令可以隐藏未编译的标签,直到实例编译结束:<div>
不会显示,直到编译结束。
[v-cloak] {
display: none;
}
<div v-cloak>{{dada}}</div>
本文由哈喽比特于3年以前收录,如有侵权请联系我们。
文章来源:https://mp.weixin.qq.com/s/ZwPLytJuiPhqq1B_M2Ag_A
京东创始人刘强东和其妻子章泽天最近成为了互联网舆论关注的焦点。有关他们“移民美国”和在美国购买豪宅的传言在互联网上广泛传播。然而,京东官方通过微博发言人发布的消息澄清了这些传言,称这些言论纯属虚假信息和蓄意捏造。
日前,据博主“@超能数码君老周”爆料,国内三大运营商中国移动、中国电信和中国联通预计将集体采购百万台规模的华为Mate60系列手机。
据报道,荷兰半导体设备公司ASML正看到美国对华遏制政策的负面影响。阿斯麦(ASML)CEO彼得·温宁克在一档电视节目中分享了他对中国大陆问题以及该公司面临的出口管制和保护主义的看法。彼得曾在多个场合表达了他对出口管制以及中荷经济关系的担忧。
今年早些时候,抖音悄然上线了一款名为“青桃”的 App,Slogan 为“看见你的热爱”,根据应用介绍可知,“青桃”是一个属于年轻人的兴趣知识视频平台,由抖音官方出品的中长视频关联版本,整体风格有些类似B站。
日前,威马汽车首席数据官梅松林转发了一份“世界各国地区拥车率排行榜”,同时,他发文表示:中国汽车普及率低于非洲国家尼日利亚,每百户家庭仅17户有车。意大利世界排名第一,每十户中九户有车。
近日,一项新的研究发现,维生素 C 和 E 等抗氧化剂会激活一种机制,刺激癌症肿瘤中新血管的生长,帮助它们生长和扩散。
据媒体援引消息人士报道,苹果公司正在测试使用3D打印技术来生产其智能手表的钢质底盘。消息传出后,3D系统一度大涨超10%,不过截至周三收盘,该股涨幅回落至2%以内。
9月2日,坐拥千万粉丝的网红主播“秀才”账号被封禁,在社交媒体平台上引发热议。平台相关负责人表示,“秀才”账号违反平台相关规定,已封禁。据知情人士透露,秀才近期被举报存在违法行为,这可能是他被封禁的部分原因。据悉,“秀才”年龄39岁,是安徽省亳州市蒙城县人,抖音网红,粉丝数量超1200万。他曾被称为“中老年...
9月3日消息,亚马逊的一些股东,包括持有该公司股票的一家养老基金,日前对亚马逊、其创始人贝索斯和其董事会提起诉讼,指控他们在为 Project Kuiper 卫星星座项目购买发射服务时“违反了信义义务”。
据消息,为推广自家应用,苹果现推出了一个名为“Apps by Apple”的网站,展示了苹果为旗下产品(如 iPhone、iPad、Apple Watch、Mac 和 Apple TV)开发的各种应用程序。
特斯拉本周在美国大幅下调Model S和X售价,引发了该公司一些最坚定支持者的不满。知名特斯拉多头、未来基金(Future Fund)管理合伙人加里·布莱克发帖称,降价是一种“短期麻醉剂”,会让潜在客户等待进一步降价。
据外媒9月2日报道,荷兰半导体设备制造商阿斯麦称,尽管荷兰政府颁布的半导体设备出口管制新规9月正式生效,但该公司已获得在2023年底以前向中国运送受限制芯片制造机器的许可。
近日,根据美国证券交易委员会的文件显示,苹果卫星服务提供商 Globalstar 近期向马斯克旗下的 SpaceX 支付 6400 万美元(约 4.65 亿元人民币)。用于在 2023-2025 年期间,发射卫星,进一步扩展苹果 iPhone 系列的 SOS 卫星服务。
据报道,马斯克旗下社交平台𝕏(推特)日前调整了隐私政策,允许 𝕏 使用用户发布的信息来训练其人工智能(AI)模型。新的隐私政策将于 9 月 29 日生效。新政策规定,𝕏可能会使用所收集到的平台信息和公开可用的信息,来帮助训练 𝕏 的机器学习或人工智能模型。
9月2日,荣耀CEO赵明在采访中谈及华为手机回归时表示,替老同事们高兴,觉得手机行业,由于华为的回归,让竞争充满了更多的可能性和更多的魅力,对行业来说也是件好事。
《自然》30日发表的一篇论文报道了一个名为Swift的人工智能(AI)系统,该系统驾驶无人机的能力可在真实世界中一对一冠军赛里战胜人类对手。
近日,非营利组织纽约真菌学会(NYMS)发出警告,表示亚马逊为代表的电商平台上,充斥着各种AI生成的蘑菇觅食科普书籍,其中存在诸多错误。
社交媒体平台𝕏(原推特)新隐私政策提到:“在您同意的情况下,我们可能出于安全、安保和身份识别目的收集和使用您的生物识别信息。”
2023年德国柏林消费电子展上,各大企业都带来了最新的理念和产品,而高端化、本土化的中国产品正在不断吸引欧洲等国际市场的目光。
罗永浩日前在直播中吐槽苹果即将推出的 iPhone 新品,具体内容为:“以我对我‘子公司’的了解,我认为 iPhone 15 跟 iPhone 14 不会有什么区别的,除了序(列)号变了,这个‘不要脸’的东西,这个‘臭厨子’。