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

静态化网站和app的区别jsp网站开发的参考文献

静态化网站和app的区别,jsp网站开发的参考文献,网页设计教程大全,docker wordpress 80好的,这是一个非常核心的编程概念,理解它对于写出高质量代码至关重要。 我们可以从一个生活中的比喻开始。 副作用的起源:医学比喻 这个词最初来源于医学。你吃一种药是为了治疗头痛(这是药的主要作用),…

好的,这是一个非常核心的编程概念,理解它对于写出高质量代码至关重要。

我们可以从一个生活中的比喻开始。

副作用的起源:医学比喻

这个词最初来源于医学。你吃一种药是为了治疗头痛(这是药的主要作用),但这种药可能会让你犯困(这就是副作用)。

“犯困”这个效果,并不是你吃药想要达成的首要目标,但它确实发生了,并对你的状态产生了影响。


编程中的“副作用”

在编程中,一个函数或表达式的“主要作用”是计算并返回一个值

如果它在做这件事的同时,还对外部世界产生了任何可观测到的影响或改变,那么这些额外的、非返回值的“影响或改变”就是它的“副作用”(Side Effect)。

纯函数 (Pure Function) - 没有副作用的理想情况

为了更好地理解副作用,我们先看它的反面——纯函数。一个纯函数必须满足两个条件:

  1. 无副作用:它不会修改任何外部的状态。
  2. 引用透明:对于相同的输入,永远返回相同的输出。

纯函数示例:

// 这是一个纯函数
// 1. 它没有修改任何外部变量。
// 2. 无论调用多少次,只要输入是 2 和 3,输出永远是 5。
function sum(a, b) {return a + b; 
}

这个 sum 函数就像一个完美的数学公式,它的唯一职责就是根据输入计算出一个值。

带有副作用的函数 (Impure Function)

现在来看带有副作用的例子。

副作用的常见类型:

  1. 修改外部变量(最常见的副作用)

    let count = 0;// 这个函数有副作用,因为它修改了外部的 count 变量
    function increment() {count++; // <--- 这就是副作用
    }
    
  2. 修改传入的参数(如果参数是对象或数组)

    function addHobby(user, hobby) {// 这个函数有副作用,因为它修改了传入的 user 对象user.hobbies.push(hobby); // <--- 副作用
    }
    
  3. 任何 I/O 操作 (Input/Output)

    • DOM 操作document.getElementById('app').innerHTML = 'Hello';
    • 网络请求fetch('/api/data')
    • 写入磁盘或数据库
    • 打印到控制台console.log('message') (因为它与外部的“控制台”系统发生了交互)

回到 Vue 的场景:为什么要在意副作用?

现在我们可以清晰地理解为什么 Vue 对 {{ }}@click 有不同的规则了:

  • {{ }} (插值表达式) - “纯净区域”

    • 职责:它的唯一职责是像一个纯函数那样,根据当前的数据计算出一个值并显示出来
    • 为什么禁止副作用:如果 {{ }} 里的代码可以随意修改外部数据(产生副作用),那么整个应用的状态就会变得混乱且不可预测。Vue 将无法有效地追踪数据变化并优化渲染。比如 {{ count++ }},它一边要显示 count 的值(主要作用),一边又在偷偷地修改它(副作用),这就把事情搞乱了。
  • @click (事件处理器) - “副作用专区”

    • 职责:它的唯一职责就是响应用户的动作,并执行能改变程序状态的副作用
    • 为什么允许副作用:用户点击按钮,就是为了触发一个改变。比如 @click="count++",我们在这里根本不关心它的返回值,我们只关心它产生的副作用——让 count 的值加一。这正是事件处理器的天职。

总结

简单来说,“副作用”就是一个函数或表达式在“返回值”这个主要任务之外,对程序状态或外部环境所做的任何修改

在编程中,我们倾向于将有副作用的代码和无副作用的纯逻辑代码分离开来,因为这样做:

  • 提高了代码的可预测性:纯函数更容易测试和推理。
  • 便于性能优化:框架可以安全地缓存纯函数的计算结果。
  • 使代码更易于维护:职责清晰,问题排查更简单。

这正是 Vue 将“展示逻辑” ({{ }}) 和“行为逻辑” (@click) 分开的核心原因。

http://www.dtcms.com/wzjs/812952.html

相关文章:

  • 现在给别人做网站还赚钱吗海尔电子商务网站建设情况
  • 大连市建设学校网站网络推广的优点
  • 安徽公路建设行业协会网站是哪个网站报价明细表
  • 网站备案变更 能让首页关闭 二级域名继续微信推广方案范文
  • 家用电脑怎么做网站做网站要到通信管理局备案
  • 廊坊建设网站公司造价师在哪个网站做继续教育
  • 网站英文联系我们WordPress百家号同步插件
  • dz旅游网站模板深圳设计装修公司
  • 怎样制作免费手机网站腾讯云服务器怎么重启
  • 司法局网站建设工作汇报郑州网络建
  • 南京百度推广网站东营网站关键词
  • jquery 的网站模板下载地址怎么做html5网站
  • 制作网站的公司叫什么wordpress skype 插件
  • 山西网站推angularjs 网站模板
  • 百度站长工具app织梦能做视频网站吗
  • 汽车电子商务网站建设wordpress安装微信登录插件
  • 杭州市建设工程交易中心网站婚纱摄影网站建设公司
  • 购买一个网站需要多少钱?叫别人建个网站多少钱
  • 网校网站怎么做深圳专业网络营销外包公司
  • 九江做网站开发需要多少钱如何知道网站有没有备案
  • wap网站开发价钱wordpress 登录用户信息
  • 网站开发需要什么基础温州网站设计公司哪家好
  • 东莞做个网站中国最顶尖的服装设计公司
  • 建设行政管理部门网站各大网站的网址
  • asp网站源码 生成静态北京建设网点地址查询
  • 网站的建设怎么弄wordpress设置阅读全文
  • 公司招聘网站续费申请深圳计算机速成班培训
  • 设计师每天都上的网站深圳做微信网站公司
  • 做封面模板下载网站网站提示页面设计
  • 天津建设公司网站做网站空间备案的职业