当前位置: 首页 > news >正文

微信小程序基础加强总结

本篇文章给大家带来了关于微信小程序的相关问题,其中主要介绍了一些基础内容,包括了自定义组件、样式隔离、数据、方法和属性等等内容,下面一起来看一下,希望对大家有帮助。

1、自定义组件

1.1、创建组件

  • 在项目的根目录中,鼠标右键,创建 components -> test 文件夹

  • 新建的 components -> test 文件夹上,鼠标右键,点击新建 Component

  • 键入组件的名称之后回车,会自动生成组件对应的 4 个文件,后缀名分别为 .js、.json、.wxml 和 .wxss

1.2、引用组件

  • 局部引用:组件只能在当前被引用的页面内使用

  • 全局引用:组件可以在每个小程序页面中使用

1.3、局部引用组件

在页面的 .json 配置文件中引用组件的方式,叫做局部引用。示例代码如下:

 

# 在页面的 .json 文件中,引入组件
{"usingComponents": {"my-test": "/components/test/test"}
}
# 在页面的 .wxml 文件中,使用组件
<my-test></my-test>

1.4、全局引用组件

在 app.json 全局配置文件中引用组件的方式,叫做全局引用。示例代码如下:

# 在 app.json 文件中,引入组件
{"usingComponents": {"my-test": "/components/test/test"}
}

 

1.5、全局引用 VS 局部引用

根据组件的使用频率和范围,来选择合适的引用方式:

  • 如果某组件在多个页面中经常被用到,建议进行全局引用

  • 使用某组件只在特定的页面中被用到,建议进行局部引用

1.6、组件和页面的区别

从表面来看,组件和页面都是由 .js、.json、.wxml 和 .wxss 这四个文件组成的。但是,组件和页面的 .js 与 .json 文件有明显的不同:

  • 组件的 .json 文件中需要声明 "component": true 属性

  • 组件的 .js 文件中调用的是 Component() 函数

  • 组件的事件处理函数需要定义到 methods 节点中

2、样式隔离

2.1、组件样式隔离

默认情况下,自定义组件的样式只对当前组件生效,不会影响到组件之外的 UI 结构。

防止外界的样式影响组件内部的样式

防止组件的样式破坏外界的样式

2.2、组件样式隔离的注意点

app.wxss 中的全局样式对组件无效

只有 class 选择器会有样式隔离效果,id 选择器、属性选择器、标签选择器不受样式隔离影响

在组件和引用组件的页面中建议使用 class 选择器,不要使用 id、属性、标签选择器

2.3、修改组件的样式隔离选项

默认情况下,自定义组件的样式隔离特性能够防止组件内外样式互相干扰的问题。但有时,我们希望在外界能够控制组件内部的样式。此时,可以通过 stylelsolation 修改组件的样式隔离选项,用法如下:

# 在组件的 .js 文件中新增如下配置
Component({options: {stylelsolation: 'isolated'}
})
# 或在组件的 .json 文件中新增如下配置
{"stylelsolation": "isolated"
}

 

2.4、stylelsolation 的可选值

| 可选值 | 默认值 | 描述 |

| isolated | 是 | 表示启用样式隔离 | 表示启用样式隔离,在自定义组件内外,使用 class 指定的样式将不会互相影响 |

| apply-shared | 否 | 表示页面 wxss 样式将影响到自定义组件,但自定义组件 wxss 中指定的样式不会影响页面 |

| shared | 否 | 表示页面 wxss 样式将影响到自定义组件,自定义组件 wxss 中指定的样式也会影响页面和其他设置了 apply-shared 或 shared 的自定义组件 |

3、数据、方法和属性

3.1、data 数据

在小程序组件中,用于组件模板渲染和私有数据,需要定义到 data 节点中,示例如下:

Component({<!-- 组件的初始数据 -->data: {count: 0}
})

 

3.2、methods 数据

在小程序组件中,事件处理函数和自定义方法需要定义到 methods 节点中,示例代码如下:

Component({<!-- 组件的方法列表 -->methods: {<!-- 事件处理函数 -->addCount() {this.setData({count: this.data.count + 1});<!-- 通过 this 直接调用自定义方法 -->this._showCount()},<!-- 自定义方法建议以 _ 开头 -->_showCount() {wx.showToast({title: 'count值为:' + this.data.count,icon: 'none'})}}
})

 

3.3、properties 属性

在小程序组件中,properties 是组件的对外属性,用来接收外界传递到组件中的数据,示例代码如下:

Component({<!-- 属性定义 -->properties: {<!-- 完整定义属性的方式 -->max: {type: Number,value: 10},<!-- 简化定义属性的方式 -->max: Number}
})

 

3.4、data 和 properties 的区别

在小程序的组件中,properties 属性和 data 数据的用法相同,它们都是可读可写的,只不过:

  • data 更倾向于存储组件的私有数据

  • properties 更倾向于存储外界传递到组件中的数据

Component({methods: {showInfo() {<!-- 结果为 true,证明 data 数据和 properties 属性本质上是一样的,都是可读可写的 -->console.log(this.data === this.properties)}}
})

 

3.5、使用 setData 修改 properties 的值

由于 data 数据和 properties 属性在本质上没有任何区别,因此 properties 属性的值也可以用于页面渲染,或使用 setData 为 properties 中的属性重新赋值,示例代码如下:

# 在组建的 .wxml 文件中使用 properties 属性的值
<view>max属性的值为:{{max}}</view>
Component({properties: { max: Number },methods: {addCount() {this.setData({ max: this.properties.max + 1 })}}
})

 

4、数据监听器

4.1、什么是数据监听器

数据监听器用于监听和响应任何属性和数据字段的变化,从而执行特定的操作。它的作用类似于 vue 中的 watch 侦听器。在小程序组件中,数据监听器的基本语法格式如下:

Component({observers: {'字段A, 字段B': function(字段A的心智, 字段B的新值) {}}
})

 4.2、数据监听器的基本用法

Component({data: { n1: 0, n2: 0, sum: 0 },methods: {addN1() { sthis.setData({ n1: this.data.n1 + 1 })},addN2() { sthis.setData({ n2: this.data.n2 + 1 })}},observers: {'n1, n2': function(n1, n2) {this.setData({sum: n1 + n2})}}
})

 4.3、监听对象属性的变化

# 数据监听器支持监听对象中单个或多个属性的变化,示例代码如下:
Component({observers: {'对象.属性A, 对象.属性B': function(属性A的新值, 属性B的心智){}}
})
# 监听对象中所有属性的变化
Component({observers: {'obj.**': function(obj){}}
})

 

5、纯数据字段

5.1、什么是纯数据字段

纯数据字段指的是那些不用于界面渲染的 data 字段。

应用场景:例如有些情况下,某些 data 中的字段既不会展示在界面上,也不会传递给其他组件,仅仅在当前组件内部使用。带有这种特性的 data 字段适合备设置为储数据字段

好处:纯数据字段有助于提升页面更新的性能

5.2、使用规则

在 Component 构造器的 options 节点中,指定 pureDataPattern 为一个正则表达式,字段名符合这个正则表达式的字段将成为纯数据字段,示例代码如下:

Component({options: {<!-- 指定所有 _ 开头的数据字段为纯数据字段 -->pureDataPattern: /^_/},data: {a: true, // 普通数据字段_b: true // 纯数据字段}
})

 

6、组件的生命周期

6.1、组件的全部生命周期函数

 

 

6.2、组件主要的生命周期函数

在小程序组件中,最重要的生命周期函数有 3 个,分别是 created、attached、detached。它们各自的特点如下:

  • 组件实例刚被创建好的时候,created 生命周期函数会被触发

此时还不能调用 setData

通常在这个生命周期函数中,只应该用于给组件的 this 添加一些自定义的属性字段

  • 在组建完全初始化完毕、进入页面节点树后,attached 生命周期函数会被触发

此时,this.data 已被初始化完毕

这个生命周期很有用,绝大多数初始化的工作可以在这个时机进行

  • 组件离开页面节点树后,detached 生命周期函数会被触发

退出一个页面时,会触发页面内每个自定义组件的 detached 生命周期函数

此时适合做一些清理性质的工作

6.3、lifetimes 节点

在小程序组件中,生命周期函数可以直接定义在 Component 构造器的第一级参数中,可以在 lifetimes 字段内进行声明(这是推荐的方式,其优先级最高)。示例代码如下:

Component({<!-- 推荐用法 -->lifetimes: {attached() {}, // 在组件实例进入页面节点树时执行detached() {}, // 在组件实例被从页面节点树移除时执行},<!-- 以下是旧的定义方式 -->attached() {}, // 在组件实例进入页面节点树时执行detached() {}, // 在组件实例被从页面节点树移除时执行
})

 

6.4、什么是组件所在页面的生命周期

有时,自定义组件的行为依赖于页面状态的变化,此时就需要用到组件所在页面的生命周期

 

6.5、pageLifetimes 节点 

# 组件所在页面的生命周期函数,需要定义在 pageLifetimes 节点中
Component({pageLifetimes: {show: function() {}, // 页面被展示hide: function() {}, // 页面被隐藏resize: function(size) {} // 页面尺寸变化}
})

 

7、插槽

7.1、什么是插槽

在自定义组件的 wxml 结构中,可以提供一个 slot 节点(插槽),用于承载组件使用者提供的 wxml 结构。

7.2、单个插槽

在小程序中,默认每个自定义组件中只允许使用一个 slot 进行占位,这种个数上限制叫做单个插槽

<!-- 组件的封装者 -->
<view class="wrapper"><view>这里是组件的内部节点</view><!-- 对于不准确的内容,可以使用 slot 进行展位 --><slot></slot>
</view>
<!-- 组件的使用者 -->
<component><view>这里是插入到组件slot中的内容</view>
</component>

 

7.3、启用多个插槽

在小程序的自定义组件中,需要使用多个 slot 插槽是,可以在组件的 .js 文件中,通过如下方式进行启用,示例代码如下:

Component({options: {multipleSlots: true // 在组件定义时,启用多个 slot 支持}
})

 

7.4、定义多个插槽

可以在组件的 .wxml 中使用多个 slot 标签,以不同的 name 来区分不同的插槽。示例代码如下:

<!-- 组件模板 -->
<view class="wrapper"><!-- name 为 before 的第一个 slot 插槽 --><slot name="before"></slot><view>这是一段固定的文本内容</view><!-- name 为 after 的第二个 slot 插槽 --><slot name="after"></slot>
</view>

 

7.5、使用多个插槽

在使用带有多个插槽的自定义组件时,需要用 slot 属性来将节点插入到不同的 slot 中。示例代码如下:

<!-- 引用组件的页面模板 -->
<component><!-- 这部分内容将被放置在组件 <slot name="before"></slot> 的位置上 --><view slot="before">这里是插入到组件 slot name="before"中的内容</view><!-- 这部分内容将被放置在组件 <slot name="after"></slot> 的位置上 --><view slot="after">这里是插入到组件 slot name="after"中的内容</view>
</component>

 

8、父子组件之间的通信

8.1、父子组件之间的通信的 3 种方式

属性绑定

用于父组件向子组件的指定属性设置数据,仅能设置 JSON 兼容的数据

事件绑定

用于子组件向父组件传递数据,可以传递任意数据

获取组件实例

父组件还可以通过 this.selectComponent() 获取子组件实例对象

这样旧可以直接访问子组件的任意数据和方法

8.2、属性绑定

属性绑定用于实现父向子传值,而且只能传递普通类型的数据,无法将方法传递给子组件。父组件的示例代码如下:

<!-- 父组件的 data 节点 -->
data: {count: 0
}
<!-- 父组件的 wxml 结构 -->
<my-child count="{{count}}"></my-child>

 

<!-- 子组件的 properties 节点 -->
properties: {count: Number
}
<!-- 子组件的 wxml -->
<view>子组件种,count值为:{{count}}</view>

8.3、事件绑定

事件绑定用于实现子向父传值,可以传递任何类型的数据。使用步骤如下:

在父组件的 js 中,定义一个函数,这个函数即将通过自定义事件的形式,传递给子组件

<!-- 在父组件定义 syncCount 方法,将来传递给子组件,供子组件进行调用 -->
syncCount() {console.log('syncCount')
}

 在父组件的 wxml 中,通过自定义事件的形式,将步骤 1 中定义的函数引用,传递给子组件

<!-- 使用bind:自定义事件名称(推荐:结构清晰) -->
<my-test count="{{count}}" bind:sync="syncCount"></my-test>
<!-- 使用bind后面直接协商自定义事件名称-->
<my-test count="{{count}}" bindsync="syncCount"></my-test>

 在子组件的 js 中,通过调用 this.triggerEvent('自定义事件名称',{参数对象}),将数据发送到父组件

<!-- 子组件的 wxml 结构 -->
<text>子组件中,count:{{count}}</text>
<button type="primary" bindtap="addCount">+1</button>
# 子组件的 js 代码
methods: {addCount() {this.setData({count: this.properties.count + 1})this.triggerEvent('sync', { value: this.properties.count })}
}

 在父组件的 js 中,通过 e.detail 获取到子组件传递过来的数据

syncCount(e) {this.setData({count: e.detail.value})
}

 

8.4、获取组件实例

可在父组件里调用 this.selectComponent('id 或 class 选择器'),获取子组件的实例对象,从而直接访问子组件的任意数据和方法。

<my-component count="{{count}}" bind:sync="syncCount" class="test" id="test"></my-component>
<button bindtap="getChild">获取子组件实例</button>
<!-- 按钮的 tap 事件处理函数 -->
getChild() {<!-- 可以传递 id选择器,也可以传递 class 选择器 -->const child = this.selectComponent('.test')<!-- 调用子组件的 setData 方法 -->child.setData({ count: child.properties.count + 1 })<!-- 调用子组件的 addCount 方法 -->child.addCount()
}

 

9、behaviors

9.1、什么是 behaviors

behaviors 是小程序中,用于实现组件间代码共享的特性,类似于 Vue.js 中的 mixins

9.2、behaviors 的工作方式

每个 behavior 可以包含一组属性、数据、生命周期函数和方法。组件引用它时,它的属性、属性和方法会被合并到组件中。

每个组件可以引用多个 behavior,behavior 也可以引用其它 behavior

9.3、创建 behavior

调用 Behavior(Object object) 方法即可创建一个共享的 behavior 实例对象,供所有的组件使用

# 调用 Behavior() 方法,创建实例对象
# 并使用 module.exports 将 behavior 实例对象共享出去
module.exports = Behavior({# 属性节点properties: {},# 私有数据节点data: {},# 事件处理函数和自定义方法节点methods: {}
})

 

9.4、导入并使用 behavior

在组件中,使用 require() 方法导入需要的 behavior,挂载后即可访问 behavior 中的数据或方法,示例代码如下:

# 使用 require() 导入需要自定义 behavior 模块
const myBehavior = require('my-behavior')
Component({<!-- 将导入的 behavior 实例对象,挂载到 behaviors 数组节点中即可生效 -->behaviors: [myBehavior]
})

 9.5、behavior 中所有可用的节点

 

10、使用 npm 包

10.1、小程序对 npm 的支持与限制

目前,小程序已经支持使用 npm 安装第三方包,从而来提高小程序的开发效率。但是,在小程序中使用 npm 包有如下 3 个限制:

  • 不支持依赖于 Node.js 内置库的包

  • 不支持依赖于浏览器内置对象的包

  • 不支持依赖于 C++ 插件的包

10.2、API Promise 化

  • 基于回调函数的异步 API 的缺点

默认情况下,小程序官方提供的异步 API 都是基于回调函数实现的,例如,网络请求的 API 需要按照如下的方式调用:

 

wx.request({method: '',url: '',data: {},success: () => {}
})

 

缺点:容易造成回调地狱的问题,代码的可读性、维护性差

  • 什么是 API Promise 化

API Promise 化,指定是通过额外的配置,将官方提供的、基于回调函数的异步 API,升级改造为基于 Promise 的异步 API,从而提高代码的可读性、维护性、避免回调地狱的问题

  • 实现 API Promise 化

在小程序中,实现 API Promise 化主要依赖于 minprogram-api-promise 这个第三方的 npm 包。它的安装和使用步骤如下:

npm install --save minprogram-api-promise
# 在小程序入口文件中(app.js),只需要调用一次 promisifyAll() 方法
import { promisifyAll } from 'minprogram-api-promise'
const wxp = wx.p = {}
promisifyAll(wx, wxp)

 调用 Promise 化之后的异步 API

# 页面的 .wxml 结构
<button bindtap="getInfo">vant按钮</button>
# 在页面的 .js 文件中,定义对应的 tap 事件处理函数
async getInfo() {const { data: res } = await wx.p.request({method: 'GET',url: '',data: {}})
}

 

11、全局数据共享

11.1、什么是全局数据共享

全局数据共享(又叫做:状态管理)是为了解决组件之间数据共享的问题

开发中常用的数据共享方案有:Vuex、Redux、MobX 等

11.2、小程序中的全局数据共享方案

在小程序中,可使用 mobx-miniprogram 配合 mobx-miniprogram-bindings 实现全局数据共享。其中:

  • mobx-miniprogram 用来创建 Store 实例对象

  • mobx-miniprogram-bindings 用来把 Store 中的共享数据或方法,绑定到组件或页面中使用

安装 MobX 相关的包

# 在项目运行如下的命令,安装MobX相关的包
npm install --save mobx-miniprogram mobx-miniprogram-bindings

 

注意:MobX 相关的包安装完毕之后,记得删除 miniprogram_npm 目录后,重新构建 npm

创建 MobX 的 Store 实例

import { observable, action } from 'mobx-miniprogram'
export const store = observable({// 数据字段numA: 1,numB: 2,//计算属性get sum() {return this.numA + this.numB},// actions 方法,用来修改 store 中的数据updateNumA: action(function(step) {this.numA += step}),updateNumB: action(function(step) {this.numB += step}),
})

 将 Store 中的成员绑定到页面中

# 页面的 .js 文件
import { createStoreBindings } from 'mobx-miniprogram-bindings'
import { store } from './store'
Page({onLoad() {this.storeBindings = createStoreBindings(this, {store,fields: ['numA', 'numB', 'sum'],actions: ['updateNumA']})},<!-- 生命周期函数--监听页面卸载 -->onUnload() {this.storeBindings.destroyBindings()}
})

 在页面上使用 Store 中的成员

# 页面的 .wxml
<view>{{numA}} + {{numB}} = {{sum}}</view>
<van-button type="primary" bindtap="btnHandler" data-step="{{1}}">numA + 1</van-button>
<van-button type="primary" bindtap="btnHandler" data-step="{{-1}}">numA - 1</van-button>
<!-- 按钮 tap 事件的处理函数 -->
btnHandler(e) {this.updateNumA(e.target.dataset.step)
}

 将 Store 中的成员绑定到组件中

import { storeBindingsBehavior } from 'mobx-miniprogram-bindings'
import { store } from './store'
Component({behaviors: [storeBindingsBehavior],storeBindings: {store,fields: {numA: () => store.numA,numB: (store) => store.numB,sum: 'sum'},actions: {updateNumA: 'updateNumA'}}
})

 在组件中使用 Store 中的成员

# 组件的 .wxml 结构
<view>{{numA}} + {{numB}} = {{sum}}</view>
<van-button type="primary" bindtap="btnHandler" data-step="{{1}}">numA + 1</van-button>
<van-button type="primary" bindtap="btnHandler" data-step="{{-1}}">numA - 1</van-button>
<!-- 按钮 tap 事件的处理函数 -->
btnHandler(e) {this.updateNumA(e.target.dataset.step)
}

 

相关文章:

微信小程序基础加强总结

本篇文章给大家带来了关于微信小程序的相关问题&#xff0c;其中主要介绍了一些基础内容&#xff0c;包括了自定义组件、样式隔离、数据、方法和属性等等内容&#xff0c;下面一起来看一下&#xff0c;希望对大家有帮助。 1、自定义组件 1.1、创建组件 在项目的根目录中&…...

【JAVA - List】差集removeAll() 四种方法实现与优化

一、场景&#xff1a; 二、结论&#xff1a; 1. 四种方法耗时 三、代码&#xff1a; 一、场景&#xff1a; 求差集 List1 - Lsit2 二、结论&#xff1a; 1. 四种方法耗时 初始条件方法名方法思路耗时 List1.size319418 List2.size284900 List..removeAll(Lsit2)1036987ms…...

sql注入基本概念

死在山野的风里&#xff0c;活在自由的梦里 sql注入基本概念 MYSQL基本语法union合并查询2个特性&#xff1a;order by 排序三个重要的信息 Sql Server MYSQL 基本语法 登录 mysql -h ip -u user -p pass基本操作 show databases; 查看数据库crea…...

AIGC系列:1.chatgpt可以用来做哪些事情?

上图的意思&#xff1a;神器轩辕剑 那么&#xff0c;在现在AI盛行的信息时代&#xff0c; 你是否知道如何获得和利用ChatGPT这一把轩辕剑来提升你的攻击力和生存能力呢&#xff1f; 故事 程序员小张&#xff1a; 刚毕业&#xff0c;参加工作1年左右&#xff0c;日常工作是C…...

End-to-End Object Detection with Transformers(论文解析)

End-to-End Object Detection with Transformers 摘要介绍相关工作2.1 集合预测2.2 transformer和并行解码2.3 目标检测 3 DETR模型3.1 目标检测集设置预测损失3.2 DETR架构 摘要 我们提出了一种将目标检测视为直接集合预测问题的新方法。我们的方法简化了检测流程&#xff0c…...

生成多样、真实的评论(2019 IEEE International Conference on Big Data )

论文题目&#xff08;Title&#xff09;&#xff1a;Learning to Generate Diverse and Authentic Reviews via an Encoder-Decoder Model with Transformer and GRU 研究问题&#xff08;Question&#xff09;&#xff1a;评论生成&#xff0c;由上下文评论->生成评论 研…...

项目中应该使用nginx还是拦截器来封禁IP

项目中应该使用nginx还是拦截器来封禁IP 在项目中&#xff0c;使用 Nginx 或拦截器&#xff08;例如 Spring Interceptor&#xff09;来封禁 IP 地址都是可行的方法&#xff0c;具体选择取决于你的需求和项目架构。 Nginx 是一种高性能的 Web 服务器和反向代理服务器&#xf…...

SMB 协议详解之-NTLM身份认证

前面的文章说明了SMB协议交互的过程,在SMB交互的Session Setup Request/Response会对请求者的身份进行验证,这其中涉及到两个主要的协议NTLM以及Kerberos,本文将对NTLM协议进行详细的说明。 什么是NTLM NTLM是 NT LAN Manager (NTLM) Authentication Protocol 的缩写,主要…...

day34 Set

概述 Set也是集合Collection接口的子接口 Set也是集合Collection接口的子接口 特点&#xff1a;不保证元素有顺序&#xff0c;数组元素不可以重复 HashSet: 底层是基于HashMap的。元素是无序的。元素不可重复&#xff0c;去重机制是依据hashCode()和equals()方法 LinkedHas…...

数据库_之常用API的使用

数据库_之电商API MySQL C API 使用&#xff08;基本函数&#xff09; Mysql C API函数详解 MySQL的常用API 一个常用的程序调用MySQL数据库的时候通常都会调用以下API,下面来逐个分析. mysql_init() //函数原型 MYSQL *STDCALL mysql_init(MYSQL *mysql);这个API主要是用来分…...

CTreeCtrl自绘

CSWTreeCtrl.h&#xff09; #pragma once#define _OWNER_DRAWN_TREE // 自绘CTreeCtrl&#xff0c;可支持背景图片显示功能class CSWTreeCtrl : public CTreeCtrl {DECLARE_DYNAMIC(CSWTreeCtrl)// 成员私有结构定义// 构造/析构函数 public:CSWTreeCtrl();virtual ~CSWTreeC…...

目标检测YOLO实战应用案例100讲-基于深度学习的可见光遥感图像目标检测

目录 前言 遥感图像目标的特点 基于深度学习的目标检测技术 2.1引言 2.2卷积神经网络...

MySQL数据库——存储引擎(2)-存储引擎特点(InnoDB、MyISAM、Memory)、存储引擎选择

目录 存储引擎特点 InnoDB 介绍 特点 文件 逻辑存储结构 MyISAM 介绍 特点 文件 Memory 介绍 特点 文件 区别及特点 存储引擎选择 存储引擎特点 上面我们介绍了什么是存储引擎&#xff0c;以及如何在建表时如何指定存储引擎&#xff0c;接下来我们就来介绍比较…...

【Vue】构建vue项目的几种方法以及区别

【Vue】构建vue项目的几种方法以及区别 1.通过vue-cli进行创建2.直接通过npm进行创建3.基于vite创建vue项目4.总结 构建vue项目时请确保已经安装node和npm 1.通过vue-cli进行创建 要用vue脚手架vue-cli创建vue项目首先我们需要全局安装一下vue-cli&#xff0c;安装命令如下&a…...

动态封装对象,属性来自json

需求&#xff1a; 如何动态的获取一个对象的字段&#xff0c;假如一个对象里面有name,age&#xff0c;sex三个字段&#xff0c;我想取name的值&#xff0c;这个name是存在一个json中&#xff0c;json的格式如下[{"key":"name"},{"key":"age…...

【LeetCode-中等题】90. 子集 II

文章目录 组合并集问题汇总&#xff1a;题目方法一&#xff1a;递归加回溯&#xff08;去重版&#xff09; 组合并集问题汇总&#xff1a; 1、子集非去重版本 2、组合非去重版本 3、组合去重版本 题目 本题nums数组存在重复元素&#xff0c;所以本题会涉及一个去重操作&#…...

Docker如何安装seafile

SQLite 方式 要在 Docker 中安装 Seafile&#xff0c;您可以按照以下步骤进行操作&#xff1a; 安装 Docker&#xff1a;确保您的系统上已经安装了 Docker。您可以根据您的操作系统类型&#xff0c;在官方网站上找到适合您系统的 Docker 版本并进行安装。 下载 Seafile 镜像&…...

注册法国商标的步骤和时间

注册法国商标的步骤如下&#xff1a; 1、商标查询&#xff1a;在提交申请之前&#xff0c;建议进行商标查询&#xff0c;以确保商标在法国市场上具有独特性和显著性。 2、提交申请&#xff1a;通过法国知识产权局的在线平台提交商标申请。申请时&#xff0c;需要提供以下文件…...

一起学数据结构(6)——栈和队列

上篇文章中&#xff0c;对栈的概念及特点进行了解释&#xff0c;并且给出了栈实现的具体代码。本篇文章将给出队列的基本概念及特点。并给出相应的代码。 1. 队列的概念及结构&#xff1a; 在给出队列的概念之前&#xff0c;先给出上篇文章中提到的栈的概念&#xff1a;一种只…...

【数据结构】二叉树的顺序结构-堆

【数据结构】二叉树的顺序结构-堆 普通的二叉树是不适合用数组来存储的&#xff0c;因为可能会存在大量的空间浪费。而完全二叉树更适合使用顺序结构存储。现实中我们通常把堆(一种二叉树)使用顺序结构的数组来存储&#xff0c;需要注意的是这里的堆和操作系统虚拟进程地址空间…...

2024年java面试--mysql(2)

系列文章目录 2024年java面试&#xff08;一&#xff09;–spring篇2024年java面试&#xff08;二&#xff09;–spring篇2024年java面试&#xff08;三&#xff09;–spring篇2024年java面试&#xff08;四&#xff09;–spring篇2024年java面试–集合篇2024年java面试–redi…...

IllegalArgumentException

Caused by: java.lang.IllegalArgumentException:Invalid pulsar service : persistent 参数非法异常 这个异常是由于使用了无效的 Pulsar 服务类型导致的。Pulsar 支持不同的服务类型&#xff0c;例如 persistent、non-persistent 等。 当你在配置 Pulsar 相关的参数时&…...

Git 概述命令、idea中的使用

目录 Git概述 Git代码托管服务 Git常用命令 Git 全局设置 获取 Git 仓库 ​编辑Git 工作区中文件的状态 本地仓库操作 远程仓库操作 ​编辑分支操作 标签操作 在IDEA中使用Git 1.获取Git仓库 .gitignore 表示忽略 2.本地仓库操作 3.远程仓库操作 4.分支操作 Git是…...

单片机之硬件记录

一、概念 VBAT 当使用电池或其他电源连接到VBAT脚上时&#xff0c;当VDD断电时&#xff0c;可以保存备份寄存器的内容和维持RTC的功能。如果应用中没有使用外部电池&#xff0c;VBAT引脚应接到VDD引脚上。 VCC&#xff1a;Ccircuit 表示电路的意思,即接入电路的电压&#x…...

QQ文件传输协议研究

引言 我们都知道,现在越来越多的应用采取了 HTTPS or TLS 传输协议,对于一般的协议,我们可以使用中间人技术对流量进行劫持转发,从而破解密文,这边可以参见我的另外一篇文章基于加密邮件协议的中间人攻防实战, 而对于 HTTPS 应用即使是我们采取中间人技术,也很难让浏览器…...

Qt/C++音视频开发51-推流到各种流媒体服务程序

一、前言 最近将推流程序完善了很多功能,尤其是增加了对多种流媒体服务程序的支持,目前支持mediamtx、LiveQing、EasyDarwin、nginx-rtmp、ZLMediaKit、srs、ABLMediaServer等,其中经过大量的对比测试,个人比较建议使用mediamtx和ZLMediaKit,因为这两者支持的格式众多,不…...

LeetCode 35. 搜索插入位置

题目链接 力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 题目解析 该题我们可以采用二分查找的方式&#xff0c;我们可以把数组分为&#xff0c;小于target的一边儿和大于等于target的一边儿。 当midleft(right-left)下标所对应的数大于等于targ…...

7年经验之谈 —— Web测试是什么,有何特点?

Web测试是指对Web应用程序进行验证和评估的过程&#xff0c;以确保其功能、性能和安全性符合预期。 Web测试具体包括以下几个方面的内容&#xff1a; 功能测试&#xff1a;验证Web应用程序是否按照需求规格说明书中定义的功能正常工作。功能测试包括输入验证、表单提交、页面…...

【数据结构】前言概况 - 树

&#x1f6a9;纸上得来终觉浅&#xff0c; 绝知此事要躬行。 &#x1f31f;主页&#xff1a;June-Frost &#x1f680;专栏&#xff1a;数据结构 &#x1f525;该文章针对树形结构作出前言&#xff0c;以保证可以对树初步认知。 目录&#xff1a; &#x1f30d;前言:&#x1f3…...

MySQL——事务

一、事务的开始与结束 一个数据库事务由一条或多条sql语句构成&#xff0c;它们形成一个逻辑的工作单元。这些sql语句要么全部执行成功&#xff0c;要么全部执行失败。 1.1.事物的开始 1.对于DDL&#xff08;create&#xff0c;alter&#xff0c;drop&#xff09;和DCL&…...

网站客服管理系统/电子商务网站建设教程

1 在java中只有Date类型&#xff0c;这样数据存储到MySQL会出现问题&#xff0c;前台提交的数据&#xff0c;比如2018-03-20 17:30:59&#xff0c;后台用Date接受的时候&#xff0c;由于Date只精确到天&#xff0c;所以默认接收时间为2016-10-10 00:00:00&#xff0c;保存到mys…...

网站域名申请费用/站内优化怎么做

如何制作动态图片在线制作动态图片不完全教程&#xff0c;由动态图片基地【ASQQL.com】原创制作&#xff0c;如有疑问&#xff0c;请通过QQ方式与我们联系&#xff01;联系方式见网站底部&#xff01;动态图片制作步骤分为以下几步&#xff1a;第一步&#xff1a;上传视频或者寻…...

洛阳专业网站设计开发制作建站公司/推广普通话手抄报简单漂亮

题图&#xff1a;https://unsplash.com/nielsenramon在OO(面向对象)编程中&#xff0c;类中的方法有多种形式&#xff1a;实例方法、静态方法、类方法、甚至还可以有抽象方法&#xff0c;本文来说说实例方法在Python中是如何工作的&#xff0c;后面再来谈其他方法。先来定义一个…...

哈尔滨app网站开发/搜索引擎优化心得体会

Android开发&#xff0c;或者任何的互联网相关的服务&#xff0c;总免不了会使用到网络通信&#xff0c;而Android开发中&#xff0c;现今有很多优秀的框架&#xff0c;比如Volley、Okhttp3、Retrofit等&#xff0c;使用起来很方便&#xff0c;但是还是有必要了解一下整体上的网…...

秦皇岛网站关键词/百度手机版网址

如题&#xff0c;redis是采用了ziplist 元素在不足一定数量时采用压缩存储 hash: zset: list: 如上图所示&#xff1a; ziplist-entries&#xff1a;最大元素数量&#xff08;即存储了多少个元素&#xff09; ziplist-value&#xff1a;最大存储空间 Kb 以hash-max-ziplist-en…...

网站怎么做图片按按钮跳转/百度搜索引擎提交入口

晚上的时候PC问了一下这玩意&#xff0c;回忆一下极角排序 相关链接&#xff1a; How Many Triangles HDU - 5784&#xff08;极角排序&#xff0c;双指针&#xff09; 2019秦皇岛A - Angle Beats Gym - 102361A&#xff08;极角排序&#xff0c;多少个直角三角形&#xff09;…...