【前端】使用Vue3过程中遇到加载无效设置点击方法提示不存在的情况,原来是少加了一个属性

【前端】使用Vue3过程中遇到加载无效设置点击方法提示不存在的情况,原来是少加了一个属性
🌹欢迎来到《小5讲堂》🌹
🌹这是《前端》系列文章,每篇文章将以博主理解的角度展开讲解。🌹
🌹温馨提示:博主能力有限,理解水平有限,若有不对之处望指正!🌹
在这里插入图片描述

目录

前言

由于博主学习Vue基本属于自学,也没有太系统化去学习,难免有些细节会不太了解,
这次通过DeepSeek的AI应用生成的Vue3代码,直接复制使用,刚开始是可以使用的,
后来调整成平时自己喜欢的方式,发现突然无效了,后来排查发现是少了一个属性,
那么是那个属性呢,一起来看看!

提示报错

运行时,文本框应该会有个默认值,此时是空的没有初始化到值。

在这里插入图片描述


点击开始或者停止按钮,提示方法不存在。

在这里插入图片描述

问题分析

在 Vue 3 的 Composition API 中,有几种不同的方式来定义方法,是否必须放在 setup() 中取决于组件编写方式。

以下是完整的解释和解决方案:

1. Options API vs Composition API 风格差异

如果你的其他页面能直接在外面定义方法,很可能是使用了 Options API 风格(Vue 2 的传统写法),而报错的页面可能是用了 Composition API 风格<script setup>setup() 函数)。

Options API 写法(方法直接放在外面)

exportdefault{ methods:{productSpaceNotice(){// 直接定义在 methods 中console.log("方法调用");}}}

Composition API 写法(方法必须在 setup 中定义)

exportdefault{setup(){constproductSpaceNotice=()=>{// 必须在 setup() 内定义console.log("方法调用");};return{ productSpaceNotice };// 必须返回才能被模板访问}}

<script setup> 语法糖(最简洁的 Composition API)

<script setup lang="ts">// 直接在这里定义,自动暴露给模板constproductSpaceNotice=()=>{console.log("方法调用");};</script>

2. 为什么你的代码会报错?

错误 _ctx.stopCountdownis not a function 表示:

  • 但 Vue 找不到这个方法,因为:
    1. 如果你用了 setup(),但没有在 setup() 内部定义并返回这个方法
    2. 或者你用了 <script setup>,但方法定义在了 <script> 的非 setup 区域。

在模板中调用了 stopCountdown,比如:

<button@click="stopCountdown">按钮</button>

3. 解决方案

根据你的实际代码风格,选择以下对应方案:

方案 1:改用 Options API(适合从 Vue 2 迁移的代码)

exportdefault{ methods:{stopCountdown(){// 直接在这里定义console.log("方法调用");}}}

方案 2:Composition API + setup() 函数

exportdefault{setup(){conststopCountdown=()=>{// 在 setup 内定义console.log("方法调用");};return{ stopCountdown};// 必须返回}}

方案 3:<script setup> 语法糖(推荐)

<script setup lang="ts">// 直接在这里定义,无需 returnconststopCountdown=()=>{console.log("方法调用");};</script>

4. 如何统一代码风格?

如果你的项目中有些页面能用 methods,有些不能用,可能是因为:

  1. 部分组件用了 <script setup>,部分用了 setup() 函数,部分用了 Options API。
  2. 依赖的 Vue 版本或构建工具配置不一致。

建议:

  • 统一使用 <script setup>(最新推荐写法),所有方法直接定义在 <script setup> 中。
  • 如果必须用 setup() 函数,确保所有方法都在其中定义并通过 return 暴露。
  • 避免混用 Options API 和 Composition API。

5. 调试技巧

如果仍然报错,检查:

  1. 确保没有重复定义:比如同时在 setup()methods 中定义同名方法。

是否误用了 export

// 错误!不能在 <script setup> 中用 export defaultexportdefault{ methods:{...}}

<script> 标签是否有 setup 属性

<scriptsetup> // 正确 <script> // 错误(除非用 Options API) 

总结

写法类型方法定义位置是否需要 return示例
Options APImethods: { ... }Vue 2 传统写法
Composition API (setup())setup() 函数内需要手动 return
<script setup>直接写在 <script setup>最新推荐写法

根据你的习惯,选择一种风格并保持项目一致即可解决问题。

文章推荐

【前端】使用Vue3过程中遇到加载无效设置点击方法提示不存在的情况,原来是少加了一个属性

【前端】Vue3+elementui+ts,TypeScript Promise转string错误解析,习惯性请出DeepSeek来解答

【前端】Vue3+elementui+ts,给标签设置样式属性style时,提示type check failed for prop,再次请出DeepSeek来解答

【前端】layui table表格勾选事件,以及常见模块

【前端】Layui的表格常用功能,表单提交事件,表格下拉按钮点击事件,表格外的按钮点击事件

【Echarts】曲线图上方显示数字以及自定义值,标题和副标题居中,鼠标上显示信息以及自定义信息

【Echarts】柱状图上方显示数字以及自定义值,标题和副标题居中,鼠标上显示信息以及自定义信息

【随笔】程序员如何选择职业赛道,目前各个赛道的现状如何,那个赛道前景巨大

【随笔】程序员的金三银四求职宝典,每个人都有最合适自己的求职宝典

Read more

FPGA小白学习日志一:LED的点亮

1.工程准备 首先建立一个名为led的工程文件夹,文件夹下包含了doc、quartus_prj、rtl、sim四个子文件夹: 那么我们来分析各个文件夹包含了什么: doc:该文件夹主要包含了文档资料、数据手册、Visio波形等,相当于档案库; quartus_prj:该文件夹主要包括了使用Quartus II软件新建的工程,相当于操作台; rtl:该文件夹主要放置生成硬件电路的代码,相当于原材料; Sim:该文件夹放置对生成硬件电路代码的仿真文件,相当于质检室;     这四个文件夹各自完成不同的分工,但是它们之间有什么联系呢?答案是:他们之间通过路径关联和文件引用,形成一个完美的FPGA开发闭环。quartus_prj作为工程中枢,向上访问doc读取说明,向下访问rtl获取硬件代码,向外访问sim获取仿真脚本;sim向上访问rtl在逻辑上验证硬件代码的正确性。 2.设计过程    无论我们使用FPGA做什么类型的项目时,我们都要参照一个具体的流程,这里就介绍我自己的开发流程: 1.看手册和原理图,搞清楚我们需要实现什么功能,就像做饭时我们需要看食谱,要知道自己吃什么。

Science子刊|多无人机协同吊载高速钻过0.8米窄缝

Science子刊|多无人机协同吊载高速钻过0.8米窄缝

0.8米有多窄,三架无人机用缆绳协同吊起重物时,系统在悬停构型下的整体宽度约1.4m,如果不改变构型与负载姿态,根本无法通过0.8m的通道。更关键的是能否在狭窄间隙里兼顾高速机动与稳定控制? 代尔夫特理工大学Sihao Sun团队于2025年10月29日在Science Robotics发表论文“Agile and cooperative aerial manipulation of a cable-suspended load”。提出一种中心化的协同规划与控制框架:将避障与防碰撞约束纳入协同决策,实现对负载全位姿的高机动控制,从而让多机吊载系统能够完成对0.8m狭窄通道的高速穿越。 多机协同吊载 视频来源:https://www.youtube.com/watch?v=FBWN-rTK1YU 文末还附有论文与项目主页链接,方便您一键直达。如果本文对您有所帮助,欢迎在文末三连:点赞、转发和评论,支持我们继续创作更多优质内容! 技术难点 要让多无人机协同吊载既能高速机动、又能安全避障,还不依赖负载传感器,难点主要集中在: * 全位姿高机动控制难:负载位置与姿态是

【ros2】从零认识URDF:机器人模型描述的“说明书”

文章目录 * 从零认识URDF:机器人模型描述的“说明书” * 一、URDF到底是什么?能做什么? * 1. 核心定位:机器人的“数字孪生说明书” * 2. URDF的四大核心功能 * 二、URDF的基本结构:XML格式的“零件清单” * 1. 根节点:`<robot>` * 2. 核心组件一:`<link>`——机器人的“零件” * (1)`<visual>`:定义零件的“长相”(仅用于显示) * (2)`<collision>`:定义零件的“碰撞边界”(物理计算用) * (3)`<inertial>`:定义零件的“重量和惯性”(动力学计算用)

ollama 模型管理、删除模型 、open-webui 开启大模型交互

ollama 模型管理、删除模型 、open-webui 开启大模型交互

文章目录 * ollama 基本信息 * ollama 运行模型 * ollama 模型管理 * 🔧 **方法一:使用命令行删除单个模型** * ⚙️ **方法二:批量删除所有模型** * 🗑️ **方法三:彻底卸载 Ollama(含所有数据)** * ⚠️ **注意事项** * ✅ **验证是否删除成功** * open-webui 安装 开启大模型交互 * open-webui pip 安装 * open-webui 启动服务 * 浏览器访问 http://IP:8082/ : * ❤️ 时不我待,一起学AI ollama 基本信息 * https://ollama.com/ ollama 运行模型 命令行执行即可 0.6B parameter model ollama run qwen3:0.6b 1.7B