首页
学习
活动
专区
圈层
工具
发布
    • 综合排序
    • 最热优先
    • 最新优先
    时间不限
  • 来自专栏前端之攻略

    Vue.js-列表渲染 原

    指令根据一组数组的选项列表进行渲染,v-for指令需要以item in items形式的特殊语法,items是源数据数组并且item是数组元素迭代的别名 基本用法 <body class="">

    </script> <script> var app = new Vue({ el: "#app script> </body> 在v-for块中,我们拥有对父作用域属性的完全访问权限,v-for还支持一个可选的第二个参数作为当前项的索引 <body class="">
    </script> <script> var app = new Vue({ el: "#app
    <script src="js/vue.js"></script> <script> var app = new Vue({ el: "#app

    3.5K20发布于 2019-04-04
  • 来自专栏前端之攻略

    Vue.js-条件渲染 原

    但是如果我们想切换多个元素,此时我们可以把一个<template>元素当做包装元素,并在上面使用v-if,最终的渲染结果不会包含<template>元素  <body class="">

    Hi

    ' }) var app = new Vue({ el: "#app -7", data: { ok: true}, }) </script> </body> <body class="">
    Hi

    ' }) var app = new Vue({ el: "#app
    <script src="js/vue.js"></script> <script> var app = new Vue({ el: "#app

    1.8K10发布于 2019-04-04
  • 来自专栏码海

    Vue.js学习笔记(一)

    props: ['todo'], template: '

  • {{ todo.text }}
  • ' }) 现在我们就可以用v-bind指令将todo传到每一个重复的组件中了: <div id="<em>app</em> 'todo-item', { props: ['todo'], template: '<li>{{ todo.text }}</li>'})var app7 = new Vue({ el: '#<em>app</em> date-picker', { props: ['xxx'], template: 'xxx'}) 定义好了之后,我们就可以在创建和修改页面插入同样的date-picker组件了 //创建页面 <div id="app -7"> <date-picker></date-picker>
var app7 = new Vue({ el: '#app-7', data: { } }) //修改页面
<date-picker></date-picker>
var app7 = new Vue({ el: '#app-7', data: {

1.3K30发布于 2019-12-22
  • 来自专栏全栈程序员必看

    SDK封装_java封装

    本文主要讲解java封装jar包的过程,一个简单的demo,方便大家入手学习打包jar包。

    2.8K30编辑于 2022-11-03
  • 来自专栏前端之攻略

    Vue学习-简单介绍 原

      <! todo-item', { props: ['todo'], template: '
    1. {{ todo.text }}
    2. ' }) var app7 = new Vue({ el: '#app

    49920发布于 2019-04-04
  • 来自专栏撸码那些事

    封装那些事】 缺失封装

    缺失封装 没有将实现变化封装在抽象和层次结构中时,将导致这种坏味。 表现形式通常如下: 客户程序与其需要的服务变种紧密耦合,每当需要支持新变种或修改既有变种时,都将影响客户程序。 为什么不能缺失封装? 开闭原则(OCP)指出,类型应对扩展开放,对修改关闭。也就是说应该通过扩展(而不是修改)来改变类型的行为。没有在类型或层次结构中封装实现变化时,便违反了OCP。 缺失封装潜在的原因 未意识到关注点会不断变化 没有预测到关注点可能发生变化,进而没有在设计中正确封装这些关注点。 因为变化点混在了一起,没有分别进行封装。 使用桥接模式进行封装: 使用桥接模式,分别封装这两个关注点的变化。现在要引入新内容类型Data和新加密算法TDES,只需要添加两个新类。

    1.4K30发布于 2018-06-21
  • 来自专栏撸码那些事

    封装那些事】 缺失封装

    缺失封装 没有将实现变化封装在抽象和层次结构中时,将导致这种坏味。 表现形式通常如下: 客户程序与其需要的服务变种紧密耦合,每当需要支持新变种或修改既有变种时,都将影响客户程序。 为什么不能缺失封装? 开闭原则(OCP)指出,类型应对扩展开放,对修改关闭。也就是说应该通过扩展(而不是修改)来改变类型的行为。没有在类型或层次结构中封装实现变化时,便违反了OCP。 缺失封装潜在的原因 未意识到关注点会不断变化 没有预测到关注点可能发生变化,进而没有在设计中正确封装这些关注点。 因为变化点混在了一起,没有分别进行封装。 使用桥接模式进行封装: 使用桥接模式,分别封装这两个关注点的变化。现在要引入新内容类型Data和新加密算法TDES,只需要添加两个新类。

    1.4K150发布于 2018-05-16
  • 来自专栏Python学习

    封装

    前言 在面向对象编程(OOP)中,封装是一个重要的概念,旨在保护数据并限制对对象内部状态的直接访问。在 Python 中,私有成员是实现封装的关键工具。 本章详细讲解了封装的基本概念以及私有成员的用法。 本篇文章参考:黑马程序员 一、基本概念 面向对象编程是一种许多编程语言支持的编程思想。 面向对象的三大特性: 封装 继承 多态 封装:将现实世界的事物用类来描述,具体表现为属性和方法。 通俗来讲,封装就是将事物的属性和行为整合到一个类中,通过成员变量和成员方法来实现对现实世界事物的描述。

    33121编辑于 2024-08-06
  • 来自专栏产品能力

    封装

    36 // 在这里将p对象中的年龄赋值为-25岁 37 p.setAge(-25) ; 38 // 调用Person类中的talk()方法 39 p.talk() ; 40 } 41 } 封装属性 :private 属性类型 属性名 封装方法:private 方法返回类型 方法名称(参数) 01 class Person 02 { 03 private String name ; 04 private

    77920编辑于 2022-12-01
  • 来自专栏用户4381798的专栏

    封装

    专业的人专业造轮子,将橡胶、钢材等原材料封装成成品车轮,供给他人使用。 这就是封装的法则,人们通过封装,将现实世界繁复复杂的事物简化为抽象世界的一个概念,并且在概念之上层层运用封装法则,实现无与伦比的意念世界的上层建筑。

    1.1K30发布于 2020-08-28
  • 来自专栏撸码那些事

    封装那些事】 未利用封装

    未利用封装 客户代码使用显式类型检查(使用一系列if-else或switch语句检查对象的类型),而不利用出层次结构内已封装的类型变化时,将导致这种坏味。 为什么要利用封装? 我们这里讨论的是:要检查的类型都封装在了层次结构中,但没有利用这一点,即使用显式类型检查,而不依赖于动态多态性。这将导致如下问题: 显式类型检查让客户程序和具体类型紧密耦合,降低了设计的可维护性。 未利用封装潜在的原因 以过程型思维使用面向对象语言 开发时的思维是以代码执行过程为导向,自然而然就会使用if-else语句和switch语句。 未应用面向对象原则 无力将面向对象的概念付诸实践。 示例分析一 根为抽象类DataBuffer的层次结构封装了各种基本数据结构型数组,DataBuffer的子类DataBufferByte、DataBufferUShort、DataBufferInt支持相应的基本数据类型数组 这种情况反映出来的问题就是没有利用封装,已经有了层次结构,却没有予以利用。没有面向接口编程,每个地方面向的都是具体的实现类,每个地方都需要判断实例的类型才可以进行下一步的动作。

    1.5K40发布于 2018-06-21
  • 来自专栏撸码那些事

    封装那些事】 泄露的封装

    泄露的封装 抽象通过公有接口(方法)暴露或泄露实现细节时,将导致这种坏味。需要注意的是,即使抽象不存在“不充分的封装”坏味,其公有接口也有可能泄露实现细节。 为什么不能泄露封装? 为实现有效封装,必须将抽象的接口(即抽象的内容)和实现(即抽象的方式)分离。为遵循隐藏原则,必须对客户程序隐藏抽象的实现方面。 泄露的封装的潜在原因 不知道该隐藏哪些东西 开发人员通常会在无意之间泄露实现细节。 使用细粒度接口 类的公有接口直接提供了细粒度的方法,这些细粒度的方法通常会向客户程序暴露不必要的实现细节。 这就是泄露的封装的潜在原因——使用细粒度接口。

    1.1K20发布于 2018-06-21
  • 来自专栏摸鱼网工

    数据封装与解封装流程

    而是由下层逐层封装来完成对等层交换数据,这就是我们数据的封装。 而解封装,就是上层需要与下层进行通信,于是逐层解封装至目标层进行通信。 这里的上下层就是指的网络参考模型的层次 上面可能说的有点复杂不易于理解,可以记住下面这句话: 数据发送时,从上至下逐层封装 数据接收时,从下至上逐层解封装 只有拆除外层封装,才能看到内层封装 TCP/IP 五层模型对应每层格式 所遵循的层次 数据封装的流程 封装与解封装流程 1.数据从应用层发出,进入传输层 在传输层会为我们数据打上TCP or UDP头部,里面包含了我们数据的源端口、目的端口,到这层的时候 ,我们数据已经被封装成了数据段。 注意,数据的封装、解封装都是逐层进行的,不会出现跃层通信 数据的解封装封装原理一样,只不过顺序进行了颠倒,从物理层的二进制数据流开始逐层解封装直至应用层 小节 本篇了解了我们数据封装与解封装的流程,

    4.6K20编辑于 2022-12-16
  • 来自专栏撸码那些事

    封装那些事】 泄露的封装

    泄露的封装 抽象通过公有接口(方法)暴露或泄露实现细节时,将导致这种坏味。需要注意的是,即使抽象不存在“不充分的封装”坏味,其公有接口也有可能泄露实现细节。 为什么不能泄露封装? 为实现有效封装,必须将抽象的接口(即抽象的内容)和实现(即抽象的方式)分离。为遵循隐藏原则,必须对客户程序隐藏抽象的实现方面。 ##泄露的封装的潜在原因 不知道该隐藏哪些东西 开发人员通常会在无意之间泄露实现细节。 使用细粒度接口 类的公有接口直接提供了细粒度的方法,这些细粒度的方法通常会向客户程序暴露不必要的实现细节。 这就是泄露的封装的潜在原因——使用细粒度接口。

    1.2K150发布于 2018-05-15
  • 来自专栏撸码那些事

    封装那些事】 未利用封装

    未利用封装 客户代码使用显式类型检查(使用一系列if-else或switch语句检查对象的类型),而不利用出层次结构内已封装的类型变化时,将导致这种坏味。 为什么要利用封装? 我们这里讨论的是:要检查的类型都封装在了层次结构中,但没有利用这一点,即使用显式类型检查,而不依赖于动态多态性。这将导致如下问题: 显式类型检查让客户程序和具体类型紧密耦合,降低了设计的可维护性。 未利用封装潜在的原因 ###以过程型思维使用面向对象语言 开发时的思维是以代码执行过程为导向,自然而然就会使用if-else语句和switch语句。 示例分析一 根为抽象类DataBuffer的层次结构封装了各种基本数据结构型数组,DataBuffer的子类DataBufferByte、DataBufferUShort、DataBufferInt支持相应的基本数据类型数组 这种情况反映出来的问题就是没有利用封装,已经有了层次结构,却没有予以利用。没有面向接口编程,每个地方面向的都是具体的实现类,每个地方都需要判断实例的类型才可以进行下一步的动作。

    1.3K90发布于 2018-05-18
  • 来自专栏IT大咖说

    Dapper的封装、二次封装、官方扩展包封装,以及ADO.NET原生封装

    所以我们先来看看使用ADO.NET的时候我们怎么实现代码复用的封装。 ◆ 一、ADO.NET的封装案例 利用反射对ADO.NET进行封装,看代码: DBHelper.cs:这边用的是mysql,如果要用sqlserver将MySqlConnection换成SqlConnection } } } ◆ 三、Dapper的二次封装(基于上一个) 利用反射对Dapper进行二次封装:DapperSuperHelper.cs,通过继承继承dapper的封装,我们可以即可用使用原始封装又可以使用通用的对单表的增删改查 可以看到我上面的二次封装和官方的封装其实差不多的功能,不过我还多了一个分页,嘿嘿。 大家也可以自行封装

    3.4K30编辑于 2022-03-14
  • 来自专栏葡萄城控件技术团队

    使用VUE组件创建SpreadJS自定义单元格(一)

    Vue.component('todo-item', { props: ['todo'], template: '

  • {{ todo.text }}
  • ' }) // 实例化一个Vue对象,挂载在#app -7元素下,定它的属性,数组groceryList var app7 = new Vue({ el: '#app-7', data: { groceryList: [ { 在之前的内容中,我们提到了可以使用Svelte使用Web Conmponents封装其他组件可以使用的组件。

    1.9K20编辑于 2022-05-09
  • 来自专栏全栈程序员必看

    vue封装组件思路_前端封装组件

    undefined vue中v-model动态生成的实例详解 JavaScript循环遍历map数据 vue父组件调用子组件方法 vue 组件继承问题 vue2.0 如何自定义组件(vue组件的封装

    1.2K40编辑于 2022-11-09
  • 来自专栏进击的多媒体开发

    FFmpeg 实现视频 封装 与 解封装

    FFmpeg 封装实现 本例子实现的是将视频数据和音频数据,按照一定的格式封装为特定的容器,比如FLV、MKV、MP4、AVI等等。 实现的过程,可以大致用如下图表示: ? 从图中可以大致看出视频封装的流程: 首先要有编码好的视频、音频数据。 其次要根据想要封装的格式选择特定的封装器。 最后利用封装器进行封装封装的大致流程已经完成了,剩余的是一些收尾工作,比如释放分配的内存、结构体等等。 FFMpeg 解封装实现 本例子实现的是将音视频分离,例如将封装格式为 FLV、MKV、MP4、AVI 等封装格式的文件,将音频、视频分离开来。 实现的过程,可以大致用如下图表示: ? 从图中可以看出大致的节封装流程: 首先要对解复用器进行初始化。 其次将输入的封装格式文件给到解复用器内。 最后利用解封装对 Container 进行解封装

    3K30发布于 2020-07-24
  • 来自专栏撸码那些事

    封装那些事】 不充分的封装

    这准确描绘了封装原则的作用:用户无需知道抽象(汽车)的细节,此外,封装原则还让抽象能够隐藏实现细节的变化。发动机是汽油发动机还是柴油发动机并不会对我们开车造成影响。 封装原则的实现手法 隐藏实现细节 抽象向客户端程序只暴露其提供的功能,而将实现方式隐藏起来。 违反封装原则导致的坏味 我们这篇博客主要讲解分析不充分的封装坏味,对于其它封装坏味将在后面的博客讲解分析。 不充分的封装 对于抽象的一个或多个成员,声明的访问权限超过了实际需求时,将导致这种坏味。 为什么要有充分的封装封装的主要意图是将接口和实现分离,以便能够几乎独立地修改它们。这种关注点分离让客户端程序只依赖于抽象的接口,从而能够对它们隐藏实现细节。 不充分的封装的潜在原因 为方便测试 为了方便测试,开发人员常常将抽象的私有方法改成公有的。由于私有方法涉及抽象的实现细节,将其改为公有将破坏抽象的封装

    2.1K130发布于 2018-05-14
  • 第 2 页第 3 页第 4 页第 5 页第 6 页第 7 页第 8 页第 9 页第 10 页第 11 页
    点击加载更多
    领券