微信小程序开发—入门到跑路(五)

news2024/10/6 2:22:00

文章目录

        • 1. 今日目标
        • 2. 使用 npm
          • 2.1 小程序对 npm 的支持和限制
          • 问题
          • 2.2 了解什么是 vant Weapp
          • 2.3 安装 Vant 组件库
          • 问题
          • 2.4 使用 Vant 组件
          • 问题
          • 2.5 定义和使用 CSS 变量
          • 问题
          • 2.6 使用 CSS 变量定制 Vant 的主题样式
          • 问题
          • 2.7 什么是小程序 API 的 Promise 化
          • 2.8 安装并构建 miniprogram-api-promise
          • 2.9 三个步骤实现 API 的 Promise 化
          • 2.10 调用 Promise 化之后的异步 API
        • 3. 全局数据共享
          • 3.1 什么是全局数据共享
          • 3.2 小程序中的全局数据共享方案
          • 3.3 安装并构建 Mobx 相关的包
          • 3.4 创建 Store 实例对象
          • 问题
          • 3.5 定义计算属性
          • 问题
          • 3.6 定义 actions 方法
          • 问题
          • 3.7 将 Store 中的成员绑定到页面上的实现思路
          • 问题
          • 3.8 将 Store 中的成员绑定到页面上
          • 3.9 在页面中使用 Store 的成员
          • 3.10 了解 Store 中成员绑定到组件上的实现思路
          • 问题
          • 3.11 将 Store 中的成员绑定到组件上
          • 3.12 在组件中使用 Store 中的成员
        • 4. 分包
          • 4.1 了解分包的概念和好处
          • 问题
          • 4.2 分包前后项目的构成
          • 4.3 分包的加载规则
          • 4.4 分包的体积限制
          • 问题
          • 4.5 了解如何配置分包
          • 问题
          • 4.6 演示在项目中如何配置分包
          • 4.7 设置分包的别名并查看分包体积
          • 4.8 打包原则
          • 4.9 引用原则
          • 4.10 了解什么是独立分包以及它和普通分包的区别
          • 4.11 了解独立分包的应用场景
          • 4.12 将普通分包改造成独立分包
          • 问题
          • 4.13 独立分包的引用原则
          • 问题
          • 4.14 介绍分包预下载的概念以及好处
          • 4.15 配置分包的预下载
          • 4.16 分包预下载的限制

1. 今日目标

  1. 能够知道如何安装和配置 vant-weapp 组件库
  2. 能够知道如何使用 MobX 实现全局数据共享
  3. 能够知道如何对小程序的 API 进行 Promise
  4. 能够知道如何实现自定义 tabBar 的效果

2. 使用 npm

2.1 小程序对 npm 的支持和限制
问题
  • 小程序使用npm包有哪些限制?

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

  1. 不支持依赖于 Node.js 内置库的包
  2. 不支持依赖于浏览器内置对象的包
  3. 不支持依赖于 C++ 插件的包

总结:虽然 npm 上的包有千千万,但是能供小程序使用的包却“为数不多”

2.2 了解什么是 vant Weapp
  1. Vant有赞前端团队开源的移动端组件库,于 2016 年开源,已持续维护 4 年时间。Vant 对内承载了有赞所有核心业务,对外服务十多万开发者,是业界主流的移动端组件库之一
  2. 采用 MIT 开源许可协议,对商业使用比较友好
  3. 扫描下方小程序二维码,体验组件库示例

二维码这里不能发,可以自行百度搜一下

在这里插入图片描述

2.3 安装 Vant 组件库
问题
  • 如何安装Vant组件库?

    在小程序项目中,安装 Vant 组件库主要分为如下几步

  1. 通过 npm 安装

    npm init -y
    
    npm i @vant/weapp@1.3.3 -S --production
    

    使用–production会只安装dependences不会安装devDependences

  2. 构建 npm 包功能

    • 建议先点击 微信开发者工具 --> 详情 --> 本地设置 --> 使用 npm 模块
    • 然后点击 微信开发者工具 --> 菜单栏 --> 工具 --> 构建npm
    • 提示构建成功,耗时 xxx 秒且控制台没有任何的错误,说明包构建成功,可以进行使用
      • 否则就需要把 node_modulesminiprogram_npm 删除
      • 删除以后,重新安装包,并点击 工具 --> 构建npm ,进行重新构建
  3. 修改 app.json

    • styles: v2 进行移除,防止 小程序本身的 UI 样式和 Vant 的组件样式库 冲突

详细的操作地址:安装 vant

2.4 使用 Vant 组件
问题
  • 如何使用Vant组件库?

安装完 Vant 组件库之后,可以在 app.jsonusingComponents 节点中引入需要的组件,即可在 wxml 中直接使用组件

在这里插入图片描述

"usingComponents": {
  "van-button": "@vant/weapp/button/index"
}
<van-button type="default">默认按钮</van-button>
<van-button type="primary">主要按钮</van-button>
<van-button type="info">信息按钮</van-button>
<van-button type="warning">警告按钮</van-button>
<van-button type="danger">危险按钮</van-button>
2.5 定义和使用 CSS 变量
问题
  • 如何使用CSS变量?
  • CSS变量的作用域是什么?

Vant Weapp 使用 CSS 变量来实现定制主题。 关于 CSS 变量的基本用法,请参考 MDN 文档

https://developer.mozilla.org/zh-CN/docs/Web/CSS/Using_CSS_custom_propertiesopen

2.6 使用 CSS 变量定制 Vant 的主题样式
问题
  • 如何定制Vant的样式?

app.wxss 中,写入 CSS 变量,即可对全局生效

在这里插入图片描述

所有可用的颜色变量,请参考 Vant 官方提供的配置文件

https://github.com/youzan/vant-weapp/blob/dev/packages/common/style/var.less

2.7 什么是小程序 API 的 Promise 化
  1. 基于回调函数的异步 API 的缺点
    • 默认情况下,小程序官方提供的异步 API 都是基于回调函数实现的,例如,网络请求的 API 需要按照如下的方式调用
    • 这种代码的缺点是显而易见的, 容易造成回调地狱的问题,代码的可读性、维护性差!而我们就想将这种类型的代码使用 API Promise 化进行改造
  2. 什么是 API Promise
    • API Promise 化,指的是通过额外的配置,将官方提供的、基于回调函数的异步 API ,升级改造为基于 Promise 的异步 API ,从而提高代码的可读性、维护性,避免回调地狱的问题
2.8 安装并构建 miniprogram-api-promise
  1. 在小程序中,实现 API Promise 化主要依赖于 miniprogram-api-promise 这个第三方的 npm

    npm i --save miniprogram-api-promise@1.0.4
    
  2. 下载完成,我们不能直接使用这个包,而是需要再次重新构建npm包

    • 建议在构建前先删除原有的 miniprogram_npm
    • 然后再点击工具,构建 npm
2.9 三个步骤实现 API 的 Promise 化

在这里插入图片描述

  1. 在小程序入口文件中调用一次 promisifyAll()方法

    import { promisifyAll } from 'miniprogram-api-promise'
    
  2. 声明一个常量,为一个空对象

    const wxp = wx.p = {}
    
  3. 调用 promisifyAll()方法

    promisifyAll(wx, wxp)
    
  4. 上述代码是什么含义呢 ?

    • promisifyAll : 做的事就是将 wx 拥有的属性方法都 copy 并改造了一份给了 wxp 这个对象
    • 然而, wxp 只是当前 js 文件的一个常量,只能在当前文件使用
    • 因此:我们在 wx 上挂载一个属性 p 让他和 wxp 指向同一个空对象
    • 在其他页面或者组件就可以通过全局对象 wx 点出 p 来访问到 wxp
    • 此时 wx.p 发起异步的请求时,得到的是一个 promise 对象
    • 那么我们就可以使用 async/await 简化 Promise 语法
2.10 调用 Promise 化之后的异步 API

在这里插入图片描述

<van-button type="warning" bindtap="getInfo">警告按钮</van-button>
async getInfo () {
  const { data: res } = await wx.p.request({
    url: 'https://www.escook.cn/api/get',
    method: 'GET',
    data: {
      name: 'zs',
      age: 19
    }
  })

  console.log(res)
}

3. 全局数据共享

3.1 什么是全局数据共享
  1. 全局数据共享,又叫做:状态管理,是为了解决组件之间数据共享的问题
  2. 开发中常用的全局数据共享方案有: VuexReduxMobX
3.2 小程序中的全局数据共享方案
  1. 在小程序中,可使用mobx-miniprogram配合mobx-miniprogram-bindings实现全局数据共享。其中:
    • mobx-miniprogram 用来创建 Store 实例对象
    • mobx-miniprogram-bindings 用来把 Store 中的共享数据或方法,绑定到组件或页面中使用

在这里插入图片描述

3.3 安装并构建 Mobx 相关的包

在项目中运行如下的命令,安装 MobX 相关的包

npm install --save mobx-miniprogram@4.13.2 mobx-miniprogram-bindings@1.2.1 

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

3.4 创建 Store 实例对象
问题
  • 如何创建Store的实例对象?
  • 如何定义全局共享的数据?
  1. 在项目根目录下创建 store 文件夹,在文件夹中创建 store.js 文件
  2. 在文件内部,导入 mobx-miniprogram 创建 Store 实例的包
  3. 创建 Store 仓库,声明全局共享的数据,并导入
import { observable } from 'mobx-miniprogram'

export const store = observable({
  numA: 1,
  numB: 2
})
3.5 定义计算属性
问题
  • 如何定义计算属性?
  1. 在计算属性的方法前,必须加 get 修饰符,代表 sum 的值是只读的,无法进行修改
  2. 计算属性 sum 依赖于 numAnumB 的值,因此 sum 函数的返回值就是最终的值

在这里插入图片描述

import { observable } from 'mobx-miniprogram'

export const store = observable({
  // 数据字段
  numA: 1,
  numB: 2,

  // 计算属性
  get sum() {
    return this.numA + this.numB
  }
})
3.6 定义 actions 方法
问题
  • 如何更新全局共享数据?
  1. 导入 action 函数
  2. action 函数,专门用来修改 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
  })
})
3.7 将 Store 中的成员绑定到页面上的实现思路
问题
  • 如何在页面中使用Store?
  1. createStoreBindings 方法
    • 参数1: 绑定给谁:当前页面 this,当前页面的实例对象
    • 参数2: 对象 {store(容器),fields(数据)actions(修改方法)}
      • 映射容器的实例
      • 映射容器的数据字段
      • 映射容器修改的方法
  2. destroyStoreBindings 方法
    • createStoreBindings 方法的返回值,进行清理销毁的工作

在这里插入图片描述

3.8 将 Store 中的成员绑定到页面上
import { createStoreBindings } from 'mobx-miniprogram-bindings'
import { store } from '../../store/store'

Page({

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    this.storeBindings = createStoreBindings(this, {
      store,
      fields: ['numA', 'numB', 'sum'],
      actions: ['updateNumA']
    })
  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {
    this.storeBindings.destroyStoreBindings()
  }
})
3.9 在页面中使用 Store 的成员

在这里插入图片描述

<view>{{ numA }} + {{ numB }} = {{ sum }}</view>

<van-button type="warning" bindtap="btnHandler1" data-step="{{ 1 }}">
  numA + 1
</van-button>

<van-button type="primary" bindtap="btnHandler1" data-step="{{ -1 }}">
  numA -1
</van-button>
btnHandler1 (e) {
  this.updateNumA(e.target.dataset.step)
}
3.10 了解 Store 中成员绑定到组件上的实现思路
问题
  • 如何在组件中使用Store成员?

在这里插入图片描述

3.11 将 Store 中的成员绑定到组件上
import { storeBindingsBehavior } from 'mobx-miniprogram-bindings'
import { store } from '../../store/store'

Component({
  // 通过 storeBindingsBehavior 来实现自动绑定
  behaviors: [storeBindingsBehavior],

  storeBindings: {
    store, // 指定要绑定的 Store
    // 指定要绑定的字段数据
    fields: {
      numA: () => store.numA, // 绑定字段的第 1 种方式
      numB: (store) => store.numB, // 绑定数据的第 2 个方式
      sum: 'sum' // 绑定数据的第 3 个方式
    },
    // 指定要绑定的方法
    actions: {
      updateNumA: 'updateNumA'
    }
  }
})
3.12 在组件中使用 Store 中的成员
<!--components/numbers/numbers.wxml-->
<view>{{ numA }} + {{ numB }} = {{ sum }}</view>

<van-button type="warning" bindtap="btnHandler1" data-step="{{ 1 }}">
  numA + 1
</van-button>

<van-button type="primary" bindtap="btnHandler1" data-step="{{ -1 }}">
  numA -1
</van-button>
import { storeBindingsBehavior } from 'mobx-miniprogram-bindings'
import { store } from '../../store/store'

Component({
  // 通过 storeBindingsBehavior 来实现自动绑定
  behaviors: [storeBindingsBehavior],

  storeBindings: {
    store, // 指定要绑定的 Store
    // 指定要绑定的字段数据
    fields: {
      numA: () => store.numA, // 绑定字段的第 1 种方式
      numB: (store) => store.numB, // 绑定数据的第 2 个方式
      sum: 'sum' // 绑定数据的第 3 个方式
    },
    // 指定要绑定的方法
    actions: {
      updateNumA: 'updateNumA'
    }
  },

  /**
   * 组件的方法列表
   */
  methods: {
    btnHandler1 (e) {
      this.updateNumA(e.target.dataset.step)
    }
  }
})

4. 分包

4.1 了解分包的概念和好处
问题
  • 什么是分包?有什么好处?
  1. 什么是分包

    分包指的是把一个 完整的小程序项目,按照需求划分为不同的子包,在构建时打包成不同的分包,用户在使用时按需进行加载

  2. 分包的好处

    • 可以优化小程序首次启动的下载时间
    • 在多团队共同开发时可以更好的解耦协作
4.2 分包前后项目的构成
  1. 分包前项目的构成

    分包前,小程序项目中 所有的页面资源 都被打包到了一起,导致整个项目体积过大,影响小程序首次启动的下载时间

    在这里插入图片描述

  2. 分包后项目的构成

    • 分包后,小程序项目由 1 个主包 + 多个分包 组成:
      • 主包:一般只包含项目的启动页面TabBar 页面、以及所有分包都需要用到的一些公共资源
      • 分包:只包含和当前分包有关的页面和私有资源
4.3 分包的加载规则
  1. 在小程序启动时,默认会下载主包并启动主包内页面
    • tabBar 页面需要放到主包中
  2. 当用户进入分包内某个页面时,客户端会把对应分包下载下来,下载完成后再进行展示
    • 非 tabBar 页面可以按照功能的不同,划分为不同的分包之后,进行按需下载
4.4 分包的体积限制
问题
  • 分包体积有什么限制?
  1. 目前,小程序分包的大小有以下两个限制:
    • 整个小程序所有分包大小不超过 16M (主包 + 所有分包)
    • 单个分包/主包大小不能超过 2M
4.5 了解如何配置分包
问题
  • 分包前应如何配置?
  1. 更改项目的目录
  2. app.jsonsubpackages 节点中声明分包的结构

在这里插入图片描述

4.6 演示在项目中如何配置分包
  1. 配置好分包后会默认生成对应的目录
{
  "pages": [
    "pages/home/home",
    "pages/message/message",
    "pages/contact/contact",
    "pages/shoplist/shoplist"
  ],
  "subPackages": [
    {
      "root": "pkgA",
      "pages": [
        "pages/cat/cat",
        "pages/dog/dog"
      ]
    },
    {
      "root": "pkgB",
      "pages": [
        "pages/apple/apple"
      ]
    }
  ]
  "sitemapLocation": "sitemap.json"
}
4.7 设置分包的别名并查看分包体积
  1. 给每个分包添加 name 属性即可设置别名
  2. 微信开发者工具 --> 基本信息 --> 本地代码 中就可以查看分包的体积
{
  "pages": [
    "pages/home/home",
    "pages/message/message",
    "pages/contact/contact",
    "pages/shoplist/shoplist"
  ],
  "subPackages": [
    {
      "root": "pkgA",
      "name": "A",
      "pages": [
        "pages/cat/cat",
        "pages/dog/dog"
      ]
    },
    {
      "root": "pkgB",
      "name": "B",
      "pages": [
        "pages/apple/apple"
      ]
    }
  ]
  "sitemapLocation": "sitemap.json"
}
4.8 打包原则
  1. 小程序会按 subpackages 的配置进行分包, subpackages 之外的目录将被打包到主包中
  2. 主包也可以有自己的 pages (即最外层的 pages 字段)
  3. tabBar 页面必须在主包内
  4. 分包之间不能互相嵌套
4.9 引用原则
  1. 主包无法引用分包内的私有资源
  2. 分包之间不能相互引用私有资源
  3. 分包可以引用主包内的公共资源
4.10 了解什么是独立分包以及它和普通分包的区别
  1. 什么是独立分包
    • 独立分包本质上也是分包,只不过它比较特殊,可以独立于主包和其他分包而单独运行
  2. 独立分包和普通分包的区别
    • 最主要的区别:是否依赖于主包才能运行
      • 普通分包必须依赖于主包才能运行
      • 独立分包可以在不下载主包的情况下,独立运行
4.11 了解独立分包的应用场景
  1. 开发者可以按需,将某些具有一定功能独立性的页面配置到独立分包中。原因如下
    • 当小程序从普通的分包页面启动时,需要首先下载主包
    • 而独立分包不依赖主包即可运行,可以很大程度上提升分包页面的启动速度
  2. 注意:一个小程序中可以有多个独立分包
4.12 将普通分包改造成独立分包
问题
  • 独立分包如何配置?
  1. 普通分包和独立分包的区别就是在subpackages数组中,是否配置了independent这个属性
    • 和普通分包对比, 独立分包就是在 subpackages 数组的某个元素中, 配置 independent 为true即可

在这里插入图片描述

4.13 独立分包的引用原则
问题
  • 独立分包引用有什么限制?
  1. 独立分包和普通分包以及主包之间,是相互隔绝的,不能相互引用彼此的资源!例如:
    • 主包无法引用独立分包内的私有资源
    • 独立分包之间,不能相互引用私有资源
    • 独立分包和普通分包之间,不能相互引用私有资源
    • 特别注意:独立分包中不能引用主包内的公共资源
4.14 介绍分包预下载的概念以及好处
  1. 什么是分包预下载
    • 分包预下载是指在进入小程序的某个页面时,由框架自动预下载可能需要的分包,从而提升进入后续分包页面时的启动速度
  2. 分包预下载的好处
    • 提升进入后续分包页面时的启动速度
4.15 配置分包的预下载
  1. 预下载分包的行为,会在进入指定的页面时触发。在 app.json 中,使用 preloadRule 节点定义分包的预下载规则

在这里插入图片描述

// 分包预下载的规则
"preloadRule": {
  // 触发分包预下载的页面路径
  "pages/contact/contact": {
    // network 表示在指定的网络模式下进行预下载
   // 可选值有: all(不限网络)和wifi(仅 wifi 模式下进行预下载)
   // 默认值为: wifi
    "network": "all",
     // packages 表示进入页面后, 预下载哪些分包
     // 可以通过root 或name 指定预下载哪些分包
    "packages": [
      "pkgA"
    ]
  }
}
4.16 分包预下载的限制
  1. 同一个分包中的页面享有共同的预下载大小限额 2M

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/115088.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

运输层协议概述(计算机网络-运输层)

目录 运输层协议的位置 运输层为相互通信的应用进程提供了逻辑通信 应用进程之间的通信 客户-服务器通信模式 互联网的运输层协议 UDP 与 TCP 运输层的复用与分用 运输层端口的概念 端口在进程之间的通信中所起的作用 端口号 运输层协议的位置 从通信和信息处理的角度…

2022年终总结(脚踏实地,仰望星空)

2022年终总结 回忆录 2022年焦虑和快乐是这一年中最大的两种情绪了。焦虑主要是因为心里的三块石头&#xff0c;从年初就开始悬着。第一块石头&#xff0c;科研论文录用&#xff0c;第二个石头&#xff0c;拿到国奖&#xff0c;第三个石头是拿到满意的offer。目前只剩下最后一…

网络实验之EtherChannel技术实践

一、EtherChannel简介 EtherChannel简单来说就是将多个物理端口绑定为一个逻辑端口&#xff0c;通过多个端口绑定&#xff0c;能充分利用现有端口来增加带宽。构成etherchannel的端口必须配置成相同的特性&#xff0c;如双工模式、速度、同为FE或GE端口、native VLAN,、VLAN ra…

C++11标准模板(STL)- 算法(std::inner_product)

定义于头文件 <algorithm> 算法库提供大量用途的函数&#xff08;例如查找、排序、计数、操作&#xff09;&#xff0c;它们在元素范围上操作。注意范围定义为 [first, last) &#xff0c;其中 last 指代要查询或修改的最后元素的后一个元素。 计算两个范围的元素的内积…

十七、Docker Compose容器编排第二篇

在上一篇中我们讲解了容器编排是什么、能干什么、怎么安装、使用步骤&#xff0c;如果没有看的大家可以先看下&#xff1a;https://blog.csdn.net/u011837804/article/details/128335166&#xff0c;然后继续看这一篇&#xff0c;好了&#xff0c;我们继续。 1、Docker Compons…

gl-Camera

我的服务原文访问&#xff1a;Camera 1.创建摄像机的坐标系&#xff0c;&#xff08;创建原理&#xff0c;两条直线求其法向量&#xff09; Z轴:在世界坐标中指向摄像机的向量&#xff08;D&#xff09; X轴&#xff1a;随便找一个向上量和Z向量求出的法向量就是X轴&#xf…

PostgreSQL数据库TableAM——Table scan callbacks

TableAM Table scan TableAM提供了如下4个接口用于实现表数据的扫描功能。scan_begin函数的形参nkeys不为零&#xff0c;则扫描结果需要根据scan keys先进行过滤&#xff1b;pscan如果不为null&#xff0c;说明该结构体已经由parallelscan_initialize初始化过了(仅仅在table_b…

初识Docker:(5)Docker自定义镜像

初识Docker&#xff1a;&#xff08;5&#xff09;Docker自定义镜像镜像结构Dockerfile语法什么是Dockerfile构建Java项目案例1&#xff1a;基于ubuntu镜像构建一个新镜像&#xff0c;运行一个java项目案例2&#xff1a;基于java:8-alpine镜像&#xff0c;将一个java项目构建为…

Java+JSP机房课表管理系统(含源码+论文+答辩PPT等)

项目功能简介: 该项目采用技术CSSJavaScriptMySQLServlet、MySQL数据库、项目含有源码、配套开发软件、软件安装教程、项目发布教程等 项目功能介绍&#xff1a; 系统管理&#xff1a;包含用户的注册&#xff0c;管理&#xff0c;信息修改 课程管理&#xff1a;包含课程录入、维…

IT大侦“碳”:VxRail的可持续法宝

环境Environmental      社会责任Social Responsibility      企业治理Corporate Governance      随着碳达峰、碳中和的逐步推进,越来越多的“大厂”或各行业的明星企业都开始重视自己的ESG报告,已然成为了商界新风尚。      可持续发展战略也与前沿技术密切相…

matlab神经网络求解最优化,matlab神经网络训练数据

1、神经网络的准确率是怎么计算的&#xff1f; 其实神经网络的准确率的标准是自己定义的。 我把你的例子赋予某种意义讲解&#xff1a; 1&#xff0c;期望输出[1 0 0 1]&#xff0c;每个元素代表一个属性是否存在。像着4个元素分别表示&#xff1a;是否肺炎&#xff0c;是否肝…

哈希知识点

目录对比map/set1. unordered系列关联式容器1.1 unordered_map2. 底层结构2.1 哈希概念2.2 哈希冲突2.3 哈希函数2.4 哈希冲突解决2.4.1 闭散列线性探测和二次探测扩容&#xff08;负载因子&#xff09;闭散列实现的hash2.4.2 开散列概念开散列思考实现模拟实现模板参数列表的改…

Java项目:springboot农业物资管理系统

作者主页&#xff1a;源码空间站2022 简介&#xff1a;Java领域优质创作者、Java项目、学习资料、技术互助 文末获取源码 项目介绍 农业物资管理系统&#xff0c;管理员可以对角色进行配置&#xff0c;分配用户角色&#xff1b; 主要功能包含&#xff1a;登录、注册、修改密码…

并查集解决重复员工问题

简介 工作一年多了&#xff0c;天天CRUD&#xff0c;终于以前学习的算法排上用场了。 背景 我们的系统在用户注册时没有校验身份id&#xff08;身份证&#xff09;和电话号码的唯一&#xff0c;可能使用相同的身份id或者电话号码创建多个账号&#xff0c;导致有些人开多个账…

面试者推荐 |【Redis面试专题】「常见问答系列」透析Redis常见技术相关的问题1~10题(进阶)

&#x1f4da; 前提回顾 首先如果没有阅读【面试者推荐 |【Redis面试专题】「常见问答系列」透析Redis常见技术相关的问题1~10题&#xff08;基础&#xff09; 】&#xff0c;简易先去看看基础10题&#xff0c;因为循序渐进才是正道&#xff0c;哈哈。 &#x1f4da; 1. Redis…

WebRTC源码之RTCPReceiver源码分析

WebRTC源码之RTCPReceiver源码分析 WebRTC源码之RTCPReceiver源码分析WebRTC源码之RTCPReceiver源码分析前言一、 RTCP接受数据的流程的堆栈信息的1、网络io 线程读取数据2、 线程切换的代码3、 线程切换 gcc二、 RTCPReceiver::IncomingPacket方法读取RTCP数据的格式1、 Parse…

【PyTorch深度学习项目实战100例】—— 基于DPCNN实现电商情感分析任务 | 第79例

前言 大家好,我是阿光。 本专栏整理了《PyTorch深度学习项目实战100例》,内包含了各种不同的深度学习项目,包含项目原理以及源码,每一个项目实例都附带有完整的代码+数据集。 正在更新中~ ✨ 🚨 我的项目环境: 平台:Windows10语言环境:python3.7编译器:PyCharmPy…

随机种子 3407 is all you need

文 | 天于刀刀你最常用的随机种子是哪个&#xff1f;在刀刀的团队里&#xff0c;关于随机种子的设置主要分化为两派~玄学派&#xff0c;可能设置为自己的纪念日&#xff0c;又或者是星座预测中的本月幸运数字&#xff1b;以及&#xff0c;自然派&#xff0c;随机种子是啥其实无…

Java项目:springboot健身房管理系统

作者主页&#xff1a;源码空间站2022 简介&#xff1a;Java领域优质创作者、Java项目、学习资料、技术互助 文末获取源码 项目介绍 本项目为后台管理系统&#xff1b; 主要功能如下&#xff1a; 管理员登录模块 会员管理模块 教练管理模块 课程管理模块 器材管理模块 物品遗失…

一些常见的移动端适配方案,你了解吗?

前言 移动端设备的尺寸很多&#xff0c;而 UI 设计稿一般只会基于一个尺寸&#xff08;一般是 375px 或 750px &#xff09;进行设计。 目前移动端适配方案有多种&#xff0c;本文将介绍一些具有代表性的适配方案。 媒体查询 media CSS3 中的媒体查询属性 media 分别为不同…