学习记录1.14

这篇具有很好参考价值的文章主要介绍了学习记录1.14。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1.display:

2.bfc:

Bfc是块级格式化上下文   子元素不受外界影响  有自己的渲染规则 比如说:计算高度的时候浮动元素的高度也会计算在内

怎样触发BFC

绝对定位以及固定定位   flex布局 display不是none的情况  overflow:hidden

总结:

BFC就是一个块级元素,块级元素会在垂直方向一个接一个的排列

BFC就是页面中的一个隔离的独立容器,容器里的标签不会影响到外部标签

垂直方向的距离由margin决定, 属于同一个BFC的两个相邻的标签外边距会发生重叠

计算BFC的高度时,浮动元素也参与计算

BFC解决了什么问题

1.使用Float脱离文档流,发生高度塌陷

<div class="container">

        <div class="box"></div>

        <div class="box"></div>

    </div>

可以看到上面效果给box设置完float结果脱离文档流,使container高度没有被撑开,从而背景颜色没有颜色出来,解决此问题可以给container触发BFC,上面我们所说到的触发BFC属性都可以设置。

2.Margin边距重叠

可以看到上面我们为两个盒子的margin外边距设置的是10px,可结果显示两个盒子之间只有10px的距离,这就导致了margin塌陷问题,这时margin边距的结果为最大值,而不是合,为了解决此问题可以使用BFC规则(为元素包裹一个盒子形成一个完全独立的空间,做到里面元素不受外面布局影响),或者简单粗暴方法一个设置margin,一个设置padding。

<div class="container">

        <div class="box"></div>

        <p><div class="box"></div></p>

    </div>

包裹了一个p标签

3.两栏布局

可以看到上面元素,第二个div元素为300px宽度,但是被第一个div元素设置Float脱离文档流给覆盖上去了,解决此方法我们可以把第二个div元素设置为一个BFC。

也就是给第二个元素设置display:flex即可

<style> div { width: 200px; height: 100px; border: 1px solid red; } </style> 

 <body> <div style="float: left;"> 两栏布局两栏布局两栏布局两栏两栏布局两栏布局 </div> 

<div style="width: 300px;display:flex;"> 我是蛙人,如有帮助请点个赞助个赞叭,如有帮助请点个赞叭,如有帮助请点个赞叭,如有帮助请点个赞叭 </div> </body>

3.如何自适应?栅栏格式

4.vue2 vue3 $set

5.nexttick  当数据更新了,在dom中渲染后,自动执行该函数,

因为vue更新dom是异步执行的。当修改数据的时候 vue会开启一个异步队列  视图不会第一时间就进行更新 而是等所有异步队列数据都变化完毕 才会进行统一更新 

如果想要在修改数据后立刻得到更新后的DOM结构,可以使用Vue.nextTick()

什么时候使用它呢?

Vue生命周期的created()钩子函数进行的DOM操作一定要放在Vue.nextTick()的回调函数中,原因是在created()钩子函数执行的时候DOM 其实并未进行任何渲染,而此时进行DOM操作无异于徒劳,所以此处一定要将DOM操作的js代码放进Vue.nextTick()的回调函数中不然会报错。与之对应的就是mounted钩子函数,因为该钩子函数执行时所有的DOM挂载已完成。

————————————————

 更改数据后当你想立即使用js操作新的视图的时候需要使用它。 比如说 数据改变后重新获取焦点

现在有一个场景就是有一个div 使用v-if来判断它是否出现 点击一个按钮 v-if的值会改变 变成true的时候 div出现 并获取input框中的值, 如果v-if的值是 false,直接去获取div内容是获取不到的,因为此时div还没有被创建出来,那么应该在点击按钮后,改变v-if的值为 true,div才会被创建,此时再去获取,

可以使用这个函数

因为获取值的时候想要实现的效果就是 输入框一出现就自动获取焦点 并拿到里面的值。this.$refs.inputTitle.focus()不在外面嵌套$nextTick,就会出错, 因为vue是在执行完函数时候判断数据是否改变 在进行重新获取焦点 也就是说函数执行完之后input框才可见 然后获取焦点是在函数内执行的。

所以就要使用nexttick函数。因为nexttick方法是在渲染完页面之后这才执行的 就可以正常获取焦点了

————————

6.判断数据类型

instanceof.   值返回true false    判断引用数据类型

const arr = [1, 2, 3]

console.log(arr instanceof Array) // true

Typeof   判断基本数据数据类型

console.log(typeof undefined); // "undefined"

 console.log(typeof null); // "object" 

console.log(typeof {}); // "object" 

console.log(typeof []); // "object"

console.log(typeof NaN); // "number"

Object.prototype.tostring()   都可以

7.内存泄漏

内存泄漏是指不再用到的内存,没有及时释放。既不能使用,又不能回收。

导致内存泄漏的几种常见情况:

  • 1.意外形成全局变量
    解决方法:加上 ‘use strict’ 启用严格模式来避免这类问题, 严格模式会阻止你创建意外的全局变量.
  • 2.闭包
    解决方法:在函数外部定义事件处理函数,解除闭包。或在闭包中,删除没用的属性以减少对内存的消耗。或在外部函数中删除对DOM的引用。
  • 3.清除页面dom元素时,dom元素绑定的事件未解绑
    解决办法:手工移除事件。
  • 4.循环引用

function fn() {

 var a = {};

 var b = {};

 a.pro = b;

 b.pro = a;

fn();

解决办法:手工解除循环引用。

  • 5.未清除的计时器或延时器
    解决办法:clearTimeout(),clearInterval()。

=================

1.说一说设计模式

单例模式:

指在内存中只会创建并且只创建一次对象的设计模式,在程序中多次使用一个对象,并且作用相同的时候,为了防止频繁的创建对象使得内存飙升,单例模式可以让程序只在内存中创建一个对象,让所有需要调用的地方都共享这一个单例对象。

有两种类型;懒汉式和饿汉式

  • 懒汉式:在真正需要使用对象时才去创建该单例类对象
  • 饿汉式:在类加载时已经创建好该单例对象,等待被程序使用

场景例子:

  1 资源共享: 当系统中的多个部分需要共享某个资源时,使用单例模式可以确保该资源只被创建一次,避免资源浪费。

  1. 日志记录: 在需要记录日志的系统中,单例模式可以确保只有一个日志实例,以便集中管理日志信息。

使用闭包实现一个单例模式:

在这个示例中,Logger是一个立即执行函数,返回一个包含createInstance方法的对象。getInstance方法用来创建并返

回单例实例。在第一次调用getInstance时,会创建一个实例并将其存储在instance变量中,后续调用则直接返回这个实例。

这种方式使用了闭包来维护实例,并且只暴露了一个公共的访问点getInstance来获取这个实例。

观察者模式:定义对象间的一种一对多的依赖模式,当一个对象的状态发生改变的时候,所有的依赖于他的对象都得到通知并被自动更新

主要用来解决:一个对象状态改变给其他对象通知的问题,而且要考虑到易用和低耦合,保证高度的协作

观察者模式的应用

  1. 事件处理: 在前端开发中,观察者模式常用于事件处理。DOM元素的事件监听机制本质上就是观察者模式的应用。
  2. 消息订阅与发布:不同模块可以订阅感兴趣的消息,当消息发布时,所有订阅者都会收到通知。
  3. 数据绑定: 一些现代的前端框架,如Vue和React,采用了观察者模式用于数据绑定。当数据发生变化时,与之相关联的视图会自动更新。
  4. 异步编程中的回调: 观察者模式也可以用于处理异步编程中的回调。当异步操作完成时,通知所有相关的观察者执行相应的操作。

所有对象都有原型吗?

不是的,大多数对象都有原型。

然而,有一些对象例外,它们并不具有原型。

一个典型的例子是Object.prototype。Object.prototype 是原型链的最顶层,它本身不再继承其他对象,因此不具有原型。其他一些例外对象包括nullundefined。它们也没有原型,因为它们不是实例对象,它们是原始值。

常见的this指向:

  • 全局作用域中或者普通函数中this指向全局对象window
  • 立即执行函数this必定指向window
  • 定时器this指向window
  • 事件中this指向事件源对象
  • 方法中谁调用就指向谁
  • 构造函数中this指向对象实例

1.全局作用下默认绑定window        全局作用下独立调用函数绑定window

2.隐式绑定:对象內调用方法 谁调用就指向谁

 let obj = {

      name: 'obj',

      foo: function () {

        console.log(this);   //this指向obj

      }

    }

    obj.foo()

===================

let obj = {     

 name: 'obj',     

 foo: function () {     

   console.log(this);    //obj       

 function test() {       

   console.log(this);  //window 为什么? 因为test独立调用      

 }       

 test()  

   }   }    obj.foo()

===================

隐式丢失

 let obj = {     

 name: 'obj',    

  foo: function () {  

      console.log(this);  //window   为什么不是obj? bar拿到obj.foo的引用,然后在全局下独立调用    

 }   }   

 let bar = obj.foo 

   bar()

=======

3.显式绑定

call、apply、bind bind返回一个新函数,新函数指向绑定的对象,旧函数不会

4、new绑定

this指向函数实例化之后的对象

绑定规则优先级:

new绑定 > 显式绑定 > 隐式绑定 > 默认绑定

深浅拷贝:

从上图发现,浅拷贝和深拷贝都创建出一个新的对象,但在复制对象属性的时候,行为就不一样

浅拷贝只复制属性指向某个对象的指针,而不复制对象本身,新旧对象还是共享同一块内存,修改对象属性会影响原对象

// 浅拷贝

const obj1 = {

    name : 'init',

    arr : [1,[2,3],4],

};

const obj3=shallowClone(obj1) // 一个浅拷贝方法

obj3.name = "update";

obj3.arr[1] = [5,6,7] ; // 新旧对象还是共享同一块内存

console.log('obj1',obj1) // obj1 { name: 'init',  arr: [ 1, [ 5, 6, 7 ], 4 ] }

console.log('obj3',obj3) // obj3 { name: 'update', arr: [ 1, [ 5, 6, 7 ], 4 ] }

但深拷贝会另外创造一个一模一样的对象,新对象跟原对象不共享内存,修改新对象不会改到原对象

// 深拷贝

const obj1 = {

    name : 'init',

    arr : [1,[2,3],4],

};

const obj4=deepClone(obj1) // 一个深拷贝方法

obj4.name = "update";

obj4.arr[1] = [5,6,7] ; // 新对象跟原对象不共享内存

console.log('obj1',obj1) // obj1 { name: 'init', arr: [ 1, [ 2, 3 ], 4 ] }

console.log('obj4',obj4) // obj4 { name: 'update', arr: [ 1, [ 5, 6, 7 ], 4 ] }

1

2

3

4

5

6

7

8

9

10

11

#

小结

前提为拷贝类型为引用类型的情况下:

  • 浅拷贝是拷贝一层,属性为对象时,浅拷贝是复制,两个对象指向同一个地址
  • 深拷贝是递归拷贝深层次,属性为对象时,深拷贝是新开栈,两个对象指向不同的地址

← == 和 ===区别,分别在什么情况使用文章来源地址https://www.toymoban.com/news/detail-799321.html

到了这里,关于学习记录1.14的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • CSS3与HTML5

    box-sizing content-box:默认,宽高包不含边框和内边距 border-box:也叫怪异盒子,宽高包含边框和内边距 动画:移动translate,旋转、transform等等 走马灯:利用动画实现animation:from… to… 隐藏元素: visibility:hidden 占位 display:none 不占位 画页面前重置浏览器自带样式 快格式化上

    2024年02月07日
    浏览(44)
  • HTML5和CSS3笔记

    1.1:页面结构: 1.2:标签类型: 1.2.1:块标签:  1.2.2:行内标签: 1.2.3:行内块标签: 1.2.4:块标签与行内标签的转换: (可以设置在不在同一行和隐藏) 1.3:表单与表格标签:   表单:    表格:   1.4:H5标签: 1.4.1:语义标签:   1.4.2:多媒体标签: (音频audio和视

    2024年03月24日
    浏览(51)
  • HTML5CSS3提高

    HTML5 的新增特性主要是针对于以前的不足,增加了一些新的标签、新的表单和新的表单属性等。 这些新特性都有兼容性问题,基本是 IE9+ 以上版本的浏览器 才支持,如果不考虑兼容性问题,可以大量使用这些新特性。 以前布局,我们基本用 div 来做。div 对于搜索引擎来说,

    2024年02月14日
    浏览(52)
  • 尚硅谷html5+css3(3)布局

    1.文档流normal flow -网页是一个多层结构 -通过CSS可以分别为每一层设置样式 -用户只能看到最顶层 -最底层:文档流(我们所创建的元素默认都是从文档流中进行排列) 2.盒子模型   1.盒子模型-边框 2.盒子模型-内边距 3.盒子模型-外边距 4.盒子模型-水平方向的布局 5.盒子模型

    2024年04月09日
    浏览(63)
  • html5和css3的新特性

    标签         !-- 高亮 mark --         !-- 摘要概述 --         details             summary                 咖啡             /summary             ul                 li拿铁/li                 li美式/li             /ul         /details           

    2024年02月11日
    浏览(42)
  • HTML5+CSS3实现小米商城 (完整版)

    对于小米商城,也是自己初学前端的一个小作品吧,这个网页大概写了有三四天吧,总体感受就是写着还行,只要有耐心,就一定能成功。 毕竟第一次做,代码写的可能比较乱,命名可能也不是太规范,以后多加改正。 基本还原了原网页,并且只用到了CSS3和HTML5。 链接:

    2024年02月04日
    浏览(49)
  • h5(html5)+css3前端笔记二

    一、表格标签 表格的主要作用: 表格主要用于 显示、展示数据 ,因为它可以让数据显示的非常的规整,可读性非常好。特别是后台展示数据的时候,能够熟练运用表格就显得很重要。一个清爽简约的表格能够把繁杂的数据表现得很有条理。 1. table/table 用来定义表格的标签

    2024年02月14日
    浏览(65)
  • 响应式Web开发项目教程(HTML5+CSS3+Bootstrap)第2版 例3-5 CSS3 动画

    上述代码中: 第10行代码定义animation属性实现动画效果; 第10~17行代码定义rotate动画让图片从0%到100%顺时针旋转360度; 第18~20行代码通过animation动画实现当鼠标指针悬停在图片上时让图片不停的旋转。 CSS3 动画 CSS3可以创建动画,它可以取代许多网页动画图像、Flash动画和Ja

    2024年02月02日
    浏览(49)
  • 响应式Web开发项目教程(HTML5+CSS3+Bootstrap)第2版 例3-1 CSS3过渡

    上述代码中: 第8-16行代码定义.box的样式,设置透明度为1,transition的值为3s; 第18~20行代码定义元素的透明度为0,表示当鼠标指针悬停在.box元素上时元素隐藏,当鼠标离开盒子时元素显示。 在CSS3之前,由于没有过渡属性transition,当修饰CSS样式时,CSS样式属性值就会瞬间变

    2024年01月21日
    浏览(49)
  • 响应式Web开发项目教程(HTML5+CSS3+Bootstrap)第2版 第1章 HTML5+CSS3初体验 项目1-1 三栏布局页面

    三栏布局是一种常用的网页布局结构。 除了头部区域、底部区域外,中间的区域(主体区域)划分成了三个栏目,分别是左侧边栏、内容区域和右侧边栏,这三个栏目就构成了三栏布局。当浏览器的宽度发声变化时,页面中左侧边栏和右侧边栏的宽度固定不变,而内容区域的

    2024年01月17日
    浏览(85)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包