爆款云主机2核4G限时秒杀,88元/年起!
查看详情

活动

天翼云最新优惠活动,涵盖免费试用,产品折扣等,助您降本增效!
热门活动
  • 618智算钜惠季 爆款云主机2核4G限时秒杀,88元/年起!
  • 免费体验DeepSeek,上天翼云息壤 NEW 新老用户均可免费体验2500万Tokens,限时两周
  • 云上钜惠 HOT 爆款云主机全场特惠,更有万元锦鲤券等你来领!
  • 算力套餐 HOT 让算力触手可及
  • 天翼云脑AOne NEW 连接、保护、办公,All-in-One!
  • 中小企业应用上云专场 产品组合下单即享折上9折起,助力企业快速上云
  • 息壤高校钜惠活动 NEW 天翼云息壤杯高校AI大赛,数款产品享受线上订购超值特惠
  • 天翼云电脑专场 HOT 移动办公新选择,爆款4核8G畅享1年3.5折起,快来抢购!
  • 天翼云奖励推广计划 加入成为云推官,推荐新用户注册下单得现金奖励
免费活动
  • 免费试用中心 HOT 多款云产品免费试用,快来开启云上之旅
  • 天翼云用户体验官 NEW 您的洞察,重塑科技边界

智算服务

打造统一的产品能力,实现算网调度、训练推理、技术架构、资源管理一体化智算服务
智算云(DeepSeek专区)
科研助手
  • 算力商城
  • 应用商城
  • 开发机
  • 并行计算
算力互联调度平台
  • 应用市场
  • 算力市场
  • 算力调度推荐
一站式智算服务平台
  • 模型广场
  • 体验中心
  • 服务接入
智算一体机
  • 智算一体机
大模型
  • DeepSeek-R1-昇腾版(671B)
  • DeepSeek-R1-英伟达版(671B)
  • DeepSeek-V3-昇腾版(671B)
  • DeepSeek-R1-Distill-Llama-70B
  • DeepSeek-R1-Distill-Qwen-32B
  • Qwen2-72B-Instruct
  • StableDiffusion-V2.1
  • TeleChat-12B

应用商城

天翼云精选行业优秀合作伙伴及千余款商品,提供一站式云上应用服务
进入甄选商城进入云市场创新解决方案
办公协同
  • WPS云文档
  • 安全邮箱
  • EMM手机管家
  • 智能商业平台
财务管理
  • 工资条
  • 税务风控云
企业应用
  • 翼信息化运维服务
  • 翼视频云归档解决方案
工业能源
  • 智慧工厂_生产流程管理解决方案
  • 智慧工地
建站工具
  • SSL证书
  • 新域名服务
网络工具
  • 翼云加速
灾备迁移
  • 云管家2.0
  • 翼备份
资源管理
  • 全栈混合云敏捷版(软件)
  • 全栈混合云敏捷版(一体机)
行业应用
  • 翼电子教室
  • 翼智慧显示一体化解决方案

合作伙伴

天翼云携手合作伙伴,共创云上生态,合作共赢
天翼云生态合作中心
  • 天翼云生态合作中心
天翼云渠道合作伙伴
  • 天翼云代理渠道合作伙伴
天翼云服务合作伙伴
  • 天翼云集成商交付能力认证
天翼云应用合作伙伴
  • 天翼云云市场合作伙伴
  • 天翼云甄选商城合作伙伴
天翼云技术合作伙伴
  • 天翼云OpenAPI中心
  • 天翼云EasyCoding平台
天翼云培训认证
  • 天翼云学堂
  • 天翼云市场商学院
天翼云合作计划
  • 云汇计划
天翼云东升计划
  • 适配中心
  • 东升计划
  • 适配互认证

开发者

开发者相关功能入口汇聚
技术社区
  • 专栏文章
  • 互动问答
  • 技术视频
资源与工具
  • OpenAPI中心
开放能力
  • EasyCoding敏捷开发平台
培训与认证
  • 天翼云学堂
  • 天翼云认证
魔乐社区
  • 魔乐社区

支持与服务

为您提供全方位支持与服务,全流程技术保障,助您轻松上云,安全无忧
文档与工具
  • 文档中心
  • 新手上云
  • 自助服务
  • OpenAPI中心
定价
  • 价格计算器
  • 定价策略
基础服务
  • 售前咨询
  • 在线支持
  • 在线支持
  • 工单服务
  • 建议与反馈
  • 用户体验官
  • 服务保障
  • 客户公告
  • 会员中心
增值服务
  • 红心服务
  • 首保服务
  • 客户支持计划
  • 专家技术服务
  • 备案管家

了解天翼云

天翼云秉承央企使命,致力于成为数字经济主力军,投身科技强国伟大事业,为用户提供安全、普惠云服务
品牌介绍
  • 关于天翼云
  • 智算云
  • 天翼云4.0
  • 新闻资讯
  • 天翼云APP
基础设施
  • 全球基础设施
  • 信任中心
最佳实践
  • 精选案例
  • 超级探访
  • 云杂志
  • 分析师和白皮书
  • 天翼云·创新直播间
市场活动
  • 2025智能云生态大会
  • 2024智算云生态大会
  • 2023云生态大会
  • 2022云生态大会
  • 天翼云中国行
天翼云
  • 活动
  • 智算服务
  • 产品
  • 解决方案
  • 应用商城
  • 合作伙伴
  • 开发者
  • 支持与服务
  • 了解天翼云
      • 文档
      • 控制中心
      • 备案
      • 管理中心

      vue3-组合式API

      首页 知识中心 软件开发 文章详情页

      vue3-组合式API

      2025-02-21 08:55:32 阅读次数:24

      API,setup,Vue,函数,组件,选项

      组合式API

      1.1 什么是组合式API

      组合式 API (Composition API) 是一系列 API 的集合,使我们可以使用函数而不是声明选项的方式书写 Vue 组件。它是一个概括性的术语,涵盖了以下方面的 API:

      • 响应式 API:例如 ref() 和 reactive(),使我们可以直接创建响应式状态、计算属性和侦听器。

      • 生命周期钩子:例如 onMounted() 和 onUnmounted(),使我们可以在组件各个生命周期阶段添加逻辑。

      • 依赖注入:例如 provide() 和 inject(),使我们可以在使用响应式 API 时,利用 Vue 的依赖注入系统。

      组合式 API 是 Vue 3 及 Vue 2.7 的内置功能。对于更老的 Vue 2 版本,可以使用官方维护的插件 @vue/composition-api。在 Vue 3 中,组合式 API 基本上都会配合 <script setup> 语法在单文件组件中使用。

      1.2 为什么使用它

      1.2.1 更好的逻辑复用#

      组合式 API 最基本的优势是它使我们能够通过组合函数来实现更加简洁高效的逻辑复用。在选项式 API 中我们主要的逻辑复用机制是 mixins,而组合式 API 解决了 mixins 的所有缺陷。

      组合式 API 提供的逻辑复用能力孵化了一些非常棒的社区项目,比如 VueUse,一个不断成长的工具型组合式函数集合。组合式 API 还为其他第三方状态管理库与 Vue 的响应式系统之间的集成提供了一套简洁清晰的机制,例如 RxJS。

      1.2.2更灵活的代码组织#

      许多用户喜欢选项式 API 的原因是因为它在默认情况下就能够让人写出有组织的代码:大部分代码都自然地被放进了对应的选项里。然而,选项式 API 在单个组件的逻辑复杂到一定程度时,会面临一些无法忽视的限制。这些限制主要体现在需要处理多个逻辑关注点的组件中,这是我们在许多 Vue 2 的实际案例中所观察到的。

      我们以 Vue CLI GUI 中的文件浏览器组件为例:这个组件承担了以下几个逻辑关注点:

      • 追踪当前文件夹的状态,展示其内容

      • 处理文件夹的相关操作 (打开、关闭和刷新)

      • 支持创建新文件夹

      • 可以切换到只展示收藏的文件夹

      • 可以开启对隐藏文件夹的展示

      • 处理当前工作目录中的变更

      这个组件最原始的版本是由选项式 API 写成的。如果我们为相同的逻辑关注点标上一种颜色,那将会是这样:

      你可以看到,处理相同逻辑关注点的代码被强制拆分在了不同的选项中,位于文件的不同部分。在一个几百行的大组件中,要读懂代码中的一个逻辑关注点,需要在文件中反复上下滚动,这并不理想。另外,如果我们想要将一个逻辑关注点抽取重构到一个可复用的工具函数中,需要从文件的多个不同部分找到所需的正确片段。

      而如果用组合式 API 重构这个组件,将会变成下面右边这样:

      现在与同一个逻辑关注点相关的代码被归为了一组:我们无需再为了一个逻辑关注点在不同的选项块间来回滚动切换。此外,我们现在可以很轻松地将这一组代码移动到一个外部文件中,不再需要为了抽象而重新组织代码,大大降低了重构成本,这在长期维护的大型项目中非常关键。

      1.2.3 更好的类型推导#

      近几年来,越来越多的开发者开始使用 TypeScript 书写更健壮可靠的代码,TypeScript 还提供了非常好的 IDE 开发支持。然而选项式 API 是在 2013 年被设计出来的,那时并没有把类型推导考虑进去,因此我们不得不做了一些复杂到夸张的类型体操才实现了对选项式 API 的类型推导。但尽管做了这么多的努力,选项式 API 的类型推导在处理 mixins 和依赖注入类型时依然不甚理想。

      因此,很多想要搭配 TS 使用 Vue 的开发者采用了由 vue-class-component 提供的 Class API。然而,基于 Class 的 API 非常依赖 ES 装饰器,在 2019 年我们开始开发 Vue 3 时,它仍是一个仅处于 stage 2 的语言功能。我们认为基于一个不稳定的语言提案去设计框架的核心 API 风险实在太大了,因此没有继续向 Class API 的方向发展。在那之后装饰器提案果然又发生了很大的变动,在 2022 年才终于到达 stage 3。另一个问题是,基于 Class 的 API 和选项式 API 在逻辑复用和代码组织方面存在相同的限制。

      相比之下,组合式 API 主要利用基本的变量和函数,它们本身就是类型友好的。用组合式 API 重写的代码可以享受到完整的类型推导,不需要书写太多类型标注。大多数时候,用 TypeScript 书写的组合式 API 代码和用 JavaScript 写都差不太多!这也让许多纯 JavaScript 用户也能从 IDE 中享受到部分类型推导功能。

      1.2.4 更小的生产包体积#

      搭配 <script setup> 使用组合式 API 比等价情况下的选项式 API 更高效,对代码压缩也更友好。这是由于 <script setup> 形式书写的组件模板被编译为了一个内联函数,和 <script setup> 中的代码位于同一作用域。不像选项式 API 需要依赖 this 上下文对象访问属性,被编译的模板可以直接访问 <script setup> 中定义的变量,无需一个代码实例从中代理。这对代码压缩更友好,因为本地变量的名字可以被压缩,但对象的属性名则不能。

      1.3 第一个组合式API的例子

      <!DOCTYPE html>
      <html lang="en">
      <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>组合式API</title>
      </head>
      <body>
        <div id="app">
          {{ count }}
          <button @click="add">加1</button>
          <button @click="count += 10">加10</button>
        </div>
      </body>
      <script src="../lib/vue.global.js"></script>
      <script>
      ​
         Vue.createApp({
           data () {
            return {
               count: 10
             }
           },
           methods: {
             add () {
              this.count++
             }
           }
         }).mount('#app')
      ​
        const { ref } = Vue
        Vue.createApp({
          setup () { // 组合式API的标识
      ​
            const count = ref(100)
            console.log(count.value)
            const add = () => {
              // ref 创建的状态,修改是需要借助它的value属性
              count.value = count.value + 1
            }
            return { // 返回页面模版中需要使用的数据 
              count,
              add
            }
          }
        }).mount('#app')
      </script>
      </html>

      体验提取公共部分

      <!DOCTYPE html>
      <html lang="en">
      <head>
      <meta charset="UTF-8">
      <meta http-equiv="X-UA-Compatible" content="IE=edge">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <title>组合式API</title>
      </head>
      <body>
      <div id="app">
       {{ count }}
       <button @click="add">加1</button>
      </div>
      </body>
      <script src="../lib/vue.global.js"></script>
      <script>
      ​
      ​
      const { ref, onMounted, onUpdated } = Vue
       Vue.createApp({
        setup () { 
      ​
           const count = ref(0)
      ​
           const add = () => {
             count.value = count.value + 1
          }
      ​
           onMounted(() => {
             document.title = `点击了${count.value}次`
           })
      ​
          onUpdated(() => {
           document.title = `点击了${count.value}次`
          })
      ​
           return { 
             count,
            add
           }
         }
       }).mount('#app')
      ​
      function useCount () {
       const count = ref(0)
      ​
       const add = () => {
         count.value = count.value + 1
       }
      ​
       return {
         count, add
       }
      }
      ​
      ​
      function useTitle (count) {
       onMounted(() => {
         document.title = `点击了${count.value}次`
       })
      ​
       onUpdated(() => {
         document.title = `点击了${count.value}次`
       })
      }
      Vue.createApp({
       setup () { 
      ​
         const { count, add } = useCount()
      ​
         useTitle(count)
      ​
         return { 
           count,
           add
         }
       }
      }).mount('#app')
      </script>
      </html>

      setup()函数

      setup() 钩子是在组件中使用组合式 API 的入口,通常只在以下情况下使用:

      1. 需要在非单文件组件中使用组合式 API 时。

      2. 需要在基于选项式 API 的组件中集成基于组合式 API 的代码时。

      其他情况下,都应优先使用 <script setup> 语法。

      2.1 基本使用

      我们可以使用响应式 API 来声明响应式的状态,在 setup() 函数中返回的对象会暴露给模板和组件实例。其它的选项也可以通过组件实例来获取 setup() 暴露的属性

      <script>
      import { ref } from 'vue'
      ​
      export default {
        setup() {
          const count = ref(0)
      ​
          // 返回值会暴露给模板和其他的选项式 API 钩子
          return {
            count
          }
        },
      ​
        mounted() {
          console.log(this.count) // 0
        }
      }
      </script>
      ​
      <template>
        <button @click="count++">{{ count }}</button>
      </template>

      请注意在模板中访问从 setup 返回的 ref 时,它会自动浅层解包,因此你无须再在模板中为它写 .value。当通过 this 访问时也会同样如此解包。

      setup() 自身并不含对组件实例的访问权,即在 setup() 中访问 this 会是 undefined。你可以在选项式 API 中访问组合式 API 暴露的值,但反过来则不行。

      <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>组合式API</title>
      </head>
      <body>
        <div id="app">
          {{ count }}
          <button @click="add">加1</button>
        </div>
      </body>
      <script src="../lib/vue.global.js"></script>
      <script>
        const { ref, onMounted } = Vue
        Vue.createApp({
          setup () {
            const count = ref(0)
            const add = () => {
              count.value += 1
            }
            onMounted(() => {
              console.log(1111)
            })
            return {
              count,
              add
            }
          },
          data () {
            return {
              count: 10
            }
          },
          methods: {
            add () {
              this.count += 10
            }
          },
          mounted () {
            console.log('2222')
          }
        }).mount('#app')
      </script>

      生命周期先执行 组合式API 后执行选项式API,其余以组合式API为优先

      2.2 访问 Prop

      setup 函数的第一个参数是组件的 props。和标准的组件一致,一个 setup 函数的 props 是响应式的,并且会在传入新的 props 时同步更新。

      {
        props: {
          title: String,
          count: Number
        },
        setup(props) {
          console.log(props.title)
          console.log(props.count)
        }
      }

      请注意如果你解构了 props 对象,解构出的变量将会丢失响应性。因此我们推荐通过 的形式来使用其中的 props。

      如果你确实需要解构 props 对象,或者需要将某个 prop 传到一个外部函数中并保持响应性,那么你可以使用 toRefs() 和 toRef() 这两个工具函数:

      {
        setup(props) {
          // 将 `props` 转为一个其中全是 ref 的对象,然后解构
          const { title } = toRefs(props)
          // `title` 是一个追踪着 `props.title` 的 ref
          console.log(title.value)
      ​
          // 或者,将 `props` 的单个属性转为一个 ref
          const title = toRef(props, 'title')
        }
      }
      <!DOCTYPE html>
      <html lang="en">
      <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>组合式API</title>
      </head>
      <body>
        <div id="app">
          <button @click="num++">加1</button> {{ num }}
          <my-root :num="num"></my-root>
        </div>
      </body>
      <script src="../lib/vue.global.js"></script>
      <template id="root">
      <div>{{ num }} -- {{ test }}</div>
      </template>
      <script>
        const { ref, onMounted, computed } = Vue
      ​
        const Root = {
          props: ['num'],
          template: '#root',
          // setup (props) { // 千万不要对 props 解构
          //   console.log('111')
          //   return {
          //     test: computed(() => props.num) // 继续保持响应式
          //   }
          // }
          setup ({ num }) {
            console.log(num)
            return {
              test: computed(() => num) // 失去了响应式 - test的值不会发生改变
            }
          }
        }
        Vue.createApp({
          setup () {
            const num = ref(10000)
            return { num }
          },
          components: {
            MyRoot: Root
          }
        }).mount('#app')
      </script>
      </html>

      2.3 Setup的上下文

      传入 setup 函数的第二个参数是一个 Setup 上下文对象。上下文对象暴露了其他一些在 setup 中可能会用到的值:

      {
        setup(props, context) {
          // 透传 Attributes(非响应式的对象,等价于 $attrs)
          console.log(context.attrs)
      ​
          // 插槽(非响应式的对象,等价于 $slots)
          console.log(context.slots)
      ​
          // 触发事件(函数,等价于 $emit)
          console.log(context.emit)
      ​
          // 暴露公共属性(函数)
          console.log(context.expose)
        }
      }

      该上下文对象是非响应式的,可以安全地解构:

      {
        setup(props, { attrs, slots, emit, expose }) {
          ...
        }
      }

      attrs 和 slots 都是有状态的对象,它们总是会随着组件自身的更新而更新。这意味着你应当避免解构它们,并始终通过 attrs.x 或 slots.x 的形式使用其中的属性。此外还需注意,和 props 不同,attrs 和 slots 的属性都不是响应式的。如果你想要基于 attrs 或 slots 的改变来执行副作用,那么你应该在 onBeforeUpdate 生命周期钩子中编写相关逻辑。

      expose 函数用于显式地限制该组件暴露出的属性,当父组件通过模板引用访问该组件的实例时,将仅能访问 expose 函数暴露出的内容

      <!DOCTYPE html>
      <html lang="en">
      <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>setup上下文对象</title>
      </head>
      <body>
        <div id="app">
          <my-com ref="comref" class="myBox"  id="box" msg="hello msg" @my-event="getData">
            <template #header>
              header
            </template>
            <div>content</div>
            <template #footer>
              footer
            </template>
          </my-com>
        </div>
      </body>
      <template id="com">
        <div>
          <h1>子组件</h1>
          <button @click="sendData">发送数据</button>
          <slot name="header"></slot>
          <slot></slot>
          <slot name="footer"></slot>
        </div>
      </template>
      <script src="../lib/vue.global.js"></script>
      <script>
        const { createApp, ref, onMounted } = Vue
        const Com = {
          template: '#com',
          setup (props, context) {
            // attrs 获取透传过来的值
            // slots 如果使用了插槽
            // emit  子组件给父组件传值
            // expose 子组件暴露给父组件可以调用的属性和方法  ---- options API  ref获取子组件的实例
      ​
            console.log(props)
            console.log(context.attrs) // ref 不在透传之列
            console.log(context.slots)
            const sendData = () => { // 子组件给父组件传值
              context.emit('my-event', 1000)
            }
      ​
            // 自定义的属性和方法,供给父组件使用
            const a = ref(1)
            const b = ref(2)
            const c = ref(3)
      ​
            const fn = () => {
              a.value = 100
            }
      ​
            // 暴露出去的是对象
            context.expose({
              a, b, fn
            })
      ​
            return {
              sendData
            }
          }
        }
      ​
        Vue.createApp({
          setup () {
            const getData = (val) => { // 接收子组件的值
              console.log('666', val)
            }
      ​
            const comref = ref() //  comref 就是模版中ref="comref"
      ​
            onMounted(() => {
              console.log('com', comref.value) // {}
              console.log('a', comref.value.a) // 1
              console.log('b', comref.value.b) // 2
              console.log('c', comref.value.c) // undefined 因为没有暴露
              comref.value.fn()
              console.log('a', comref.value.a) // 100
            })
      ​
            return {
              getData,
              comref
            }
          },
          components: {
            MyCom: Com
          }
        }).mount('#app')
      </script>
      </html>

      在父组件通过ref获取子组件的实例的属性和方法的需求中,需要注意:

      1.如果子组件是 选项式API组件,基本不需要做任何操作

      2.如果子组件是 组合式API组件,需要通过 context.expose 暴露给父组件需要使用的属性和方法

      3.如果父组件使用 选项式API, 可以通过 this.$refs.refName 访问到子组件想要你看到的属性和方法

      4.如果父组件使用 组合式API,需要在setup中先创建 refName,然后再访问子组件想要你看到的属性和方法(const refName = ref() refName.value.X)

      2.4 与渲染函数一起使用

      setup 也可以返回一个渲染函数,此时在渲染函数中可以直接使用在同一作用域下声明的响应式状态:

      {
        setup() {
          const count = ref(0)
          return () => h('div', count.value)
        }
      }

      返回一个渲染函数将会阻止我们返回其他东西。对于组件内部来说,这样没有问题,但如果我们想通过模板引用将这个组件的方法暴露给父组件,那就有问题

      我们可以通过调用 expose() 解决这个问题:

      {
        setup(props, { expose }) {
          const count = ref(0)
          const increment = () => ++count.value
      ​
          expose({
            increment
          })
      ​
          return () => h('div', count.value)
        }
      }
      <!DOCTYPE html>
      <html lang="en">
      <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>渲染函数</title>
      </head>
      <body>
        <div id="app">
          <button @click="add">加1</button>
          <my-child ref="child"></my-child>
        </div>
      </body>
      <script src="../lib/vue.global.js"></script>
      <script>
        const { h, ref } = Vue
        const Child = {
          // 写法1:
          // template: `<div>child</div>`
          // 写法2:
          // render () {
          //   return [
          //     h('div', 'child!')
          //   ]
          // }
          // 写法3
          setup (props, { expose }) {
            const count = ref(10)
      ​
            const increment = () => {
              count.value += 1
            }
      ​
            expose({
              increment
            })
      ​
            // 返回一个函数  函数返回 渲染函数的结果
            return () => h('div', 'child!!' + count.value)
          }
        }
      ​
        Vue.createApp({
          components: {
            MyChild: Child
          },
          setup () {
            const child = ref()
      ​
            const add = () => {
              child.value.increment()
            }
      ​
            return {
              child,
              add
            }
          }
        }).mount('#app')
      </script>
      </html>
      版权声明:本文内容来自第三方投稿或授权转载,原文地址:https://qingshan09.blog.csdn.net/article/details/134499495,作者:前端青山,版权归原作者所有。本网站转在其作品的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如因作品内容、版权等问题需要同本网站联系,请发邮件至ctyunbbs@chinatelecom.cn沟通。

      上一篇:编译和连接

      下一篇:Es6-对象新增了哪些扩展?

      相关文章

      2025-05-19 09:04:44

      js小题2:构造函数介绍与普通函数对比

      js小题2:构造函数介绍与普通函数对比

      2025-05-19 09:04:44
      new , 关键字 , 函数 , 对象 , 构造函数
      2025-05-19 09:04:30

      【Canvas技法】辐射式多道光影的实现

      【Canvas技法】辐射式多道光影的实现

      2025-05-19 09:04:30
      代码 , 函数 , 实现
      2025-05-19 09:04:22

      外设驱动库开发笔记54:外设库驱动设计改进的思考

      外设驱动库开发笔记54:外设库驱动设计改进的思考

      2025-05-19 09:04:22
      使用 , 函数 , 初始化 , 定义 , 对象
      2025-05-19 09:04:14

      C语言字符函数和字符串函数--(超全超详细)

      C语言字符函数和字符串函数--(超全超详细)

      2025-05-19 09:04:14
      函数 , 字符 , 字符串
      2025-05-16 09:15:24

      如何将一串数字用函数的方法倒过来(C语言)

      如何将一串数字用函数的方法倒过来(C语言)

      2025-05-16 09:15:24
      函数 , 数字 , 数组
      2025-05-14 10:33:31

      【数据结构】第一章——绪论(2)

      【数据结构】第一章——绪论(2)

      2025-05-14 10:33:31
      函数 , 实现 , 打印 , 理解 , 算法 , 输入 , 输出
      2025-05-14 10:33:31

      计算机小白的成长历程——习题演练(函数篇)

      计算机小白的成长历程——习题演练(函数篇)

      2025-05-14 10:33:31
      函数 , 字符串 , 数组 , 知识点 , 编写 , 迭代 , 递归
      2025-05-14 10:33:25

      30天拿下Rust之高级类型

      Rust作为一门系统编程语言,以其独特的内存管理方式和强大的类型系统著称。其中,高级类型的应用,为Rust的开发者提供了丰富的编程工具和手段,使得开发者可以更加灵活和高效地进行编程。

      2025-05-14 10:33:25
      Rust , type , 代码 , 函数 , 类型 , 返回
      2025-05-14 10:33:16

      30天拿下Python之文件操作

      Python是一种高级编程语言,它提供了许多内置函数和模块来处理文件操作,主要包括:打开文件、读取文件、写入文件、关闭文件、获取目录列表等。

      2025-05-14 10:33:16
      Python , 使用 , 函数 , 文件 , 权限 , 目录
      2025-05-14 10:33:16

      C++ 11新特性之tuple

      在C++编程语言的发展历程中,C++ 11标准引入了许多开创性的新特性,极大地提升了开发效率与代码质量。其中,tuple(元组)作为一种强大的容器类型,为处理多个不同类型的值提供了便捷的手段。

      2025-05-14 10:33:16
      std , 元素 , 函数 , 初始化 , 模板 , 类型
      查看更多
      推荐标签

      作者介绍

      天翼云小翼
      天翼云用户

      文章

      33561

      阅读量

      5246446

      查看更多

      最新文章

      【Canvas技法】辐射式多道光影的实现

      2025-05-19 09:04:30

      外设驱动库开发笔记54:外设库驱动设计改进的思考

      2025-05-19 09:04:22

      C语言字符函数和字符串函数--(超全超详细)

      2025-05-19 09:04:14

      如何将一串数字用函数的方法倒过来(C语言)

      2025-05-16 09:15:24

      30天拿下Rust之高级类型

      2025-05-14 10:33:25

      30天拿下Python之文件操作

      2025-05-14 10:33:16

      查看更多

      热门文章

      Python之K8S API接口大全

      2023-03-24 10:30:38

      5 个 JavaScript “罕见”原生的 API

      2024-09-25 10:15:15

      Python 函数调用父类详解

      2023-04-23 09:44:31

      Java学习之API的概述

      2023-04-06 06:35:24

      配置docker API

      2023-05-05 10:13:08

      第二十章《Java Swing》第5节:常用组件

      2023-03-14 09:57:34

      查看更多

      热门标签

      java Java python 编程开发 代码 开发语言 算法 线程 Python html 数组 C++ 元素 javascript c++
      查看更多

      相关产品

      弹性云主机

      随时自助获取、弹性伸缩的云服务器资源

      天翼云电脑(公众版)

      便捷、安全、高效的云电脑服务

      对象存储

      高品质、低成本的云上存储服务

      云硬盘

      为云上计算资源提供持久性块存储

      查看更多

      随机文章

      STL priority_queue剖析 #C++

      一篇文章看懂 Apipost IDEA插件怎么用

      C++ STL开发温习与总结(二): 2.C++存储技术

      Linux源码阅读笔记07-进程管理4大常用API函数

      C++函数定义和调用介绍

      Python----魔法函数__str__/__repr__的用法

      • 7*24小时售后
      • 无忧退款
      • 免费备案
      • 专家服务
      售前咨询热线
      400-810-9889转1
      关注天翼云
      • 旗舰店
      • 天翼云APP
      • 天翼云微信公众号
      服务与支持
      • 备案中心
      • 售前咨询
      • 智能客服
      • 自助服务
      • 工单管理
      • 客户公告
      • 涉诈举报
      账户管理
      • 管理中心
      • 订单管理
      • 余额管理
      • 发票管理
      • 充值汇款
      • 续费管理
      快速入口
      • 天翼云旗舰店
      • 文档中心
      • 最新活动
      • 免费试用
      • 信任中心
      • 天翼云学堂
      云网生态
      • 甄选商城
      • 渠道合作
      • 云市场合作
      了解天翼云
      • 关于天翼云
      • 天翼云APP
      • 服务案例
      • 新闻资讯
      • 联系我们
      热门产品
      • 云电脑
      • 弹性云主机
      • 云电脑政企版
      • 天翼云手机
      • 云数据库
      • 对象存储
      • 云硬盘
      • Web应用防火墙
      • 服务器安全卫士
      • CDN加速
      热门推荐
      • 云服务备份
      • 边缘安全加速平台
      • 全站加速
      • 安全加速
      • 云服务器
      • 云主机
      • 智能边缘云
      • 应用编排服务
      • 微服务引擎
      • 共享流量包
      更多推荐
      • web应用防火墙
      • 密钥管理
      • 等保咨询
      • 安全专区
      • 应用运维管理
      • 云日志服务
      • 文档数据库服务
      • 云搜索服务
      • 数据湖探索
      • 数据仓库服务
      友情链接
      • 中国电信集团
      • 189邮箱
      • 天翼企业云盘
      • 天翼云盘
      ©2025 天翼云科技有限公司版权所有 增值电信业务经营许可证A2.B1.B2-20090001
      公司地址:北京市东城区青龙胡同甲1号、3号2幢2层205-32室
      • 用户协议
      • 隐私政策
      • 个人信息保护
      • 法律声明
      备案 京公网安备11010802043424号 京ICP备 2021034386号