变量使用--绑定时间

本文介绍了三种不同的变量绑定时机:编写代码时、编译程序时及运行时,并对比了硬编码与具名常量等不同方法的优劣。此外还探讨了对象实例化时绑定变量的应用场景。

所谓绑定时间就是把变量和它的值绑定在一起的时间。

编写代码时绑定

 

titleBar.color = 0xFF;//0xFF is hex value for color blue

 由于0xFF是硬编码(hard-coded)在程序里的数值,在编写代码的时候它就会绑定到titleBar.color变量上。这种硬编码技术通常是很糟糕的,因为一旦要修改这个0xFF,那么这个新值就无法同代码中其他那些必须和它一样的0xFF值保持一致了。

 

编译程序时绑定

private static final int COLOR_BLUE = 0xFF;
private static final int TITLE_BAR_COLOR = COLOR+BULE;
....

 titleBar.color = TITLE_BAR_COLOR;
TITLE_BAR_COLOR是一个具名常量,编译器会在编译时把它替换成一个数值。如果你用的语言支持这种特性,那么这种方法几乎总是要好于硬编码。
由于TITLE_BAR_COLOR比0xFF更能反映出所代表的信息,因此增加了可读性。它也能使修改标题栏颜色变得更容易,因为一处改动就能对所有位置生效。同时也不会影响运行期的性能。

 

运行时绑定

titleBar.color = ReadTitleBarColor();

 ReadTitleBarColor()是一个能在程序运行期间读入数值的子程序,数值来源可能是配置文件,也可能来自spring的注入。
与硬编码相比,这样的代码更具可读性和灵活性。无须通过修改程序来改变titleBar.color,只要简单修改ReadTitleColor()子程序要读取的数据源内容即可。

 

对象实例化时绑定

public TitleBar ConstructTitleBar(Config config){
	...
	titleBar.color = config.ReadTitleBarColor();
	...
	return titleBar;
}

 ConstructTitleBar()是一个能在对象实例化的时候通过配置中相应的方法来设置color。

源码地址: https://pan.quark.cn/s/a4b39357ea24 欧姆龙触摸屏编程软件MPTST 5.02是专门为欧姆龙品牌的工业触摸屏而研发的编程解决方案,它赋予用户在直观界面上构建、修改以及排错触摸屏应用程序的能力。 该软件在工业自动化领域具有不可替代的地位,特别是在生产线监视、设备操控以及人机互动系统中发挥着核心作用。 欧姆龙MPTST(Machine Process Terminal Software Touch)5.02版本配备了多样化的功能,旨在应对不同种类的触摸屏项目要求。 以下列举了若干核心特性:1. **图形化编程**:MPTST 5.02采用图形化的编程模式,允许用户借助拖拽动作来设计屏幕布局,设定按钮、滑块、指示灯等组件,显著简化了编程流程,并提升了工作效率。 2. **兼容性**:该软件能够适配欧姆龙的多个触摸屏产品线,包括CX-One、NS系列、NJ/NX系列等,使用户可以在同一个平台上完成对不同硬件的编程任务。 3. **数据通信**:MPTST 5.02具备PLC(可编程逻辑控制器)进行数据交互的能力,通过将触摸屏作为操作界面,实现生产数据的显示输入,以及设备状态的监控。 4. **报警事件管理**:软件中集成了报警和事件管理机制,可以设定多种报警标准,一旦达到预设条件,触摸屏便会展示对应的报警提示,助力操作人员迅速做出响应。 5. **模拟测试**:在设备实际连接之前,MPTST 5.02支持用户进行脱机模拟测试,以此验证程序的正确性稳定性。 6. **项目备份恢复**:为了防止数据遗失,MPTST 5.02提供了项目文件的备份及还原功能,对于多版本控制团队协作具有显著价值。 7. **多语言支持**:针对全球化的应...
### 实现 UniApp 中 `uni-datetime-picker` 默认显示当前日期 在 UniApp 的开发环境中,可以通过设置 `value` 属性来指定 `uni-datetime-picker` 组件的默认值。为了使该组件默认显示当前日期,可以利用 JavaScript 获取当前的时间戳并将其传递给组件。 以下是具体的实现方式: #### 示例代码 ```javascript <template> <view> <!-- 使用 uni-datetime-picker --> <uni-datetime-picker type="daterange" :start="startDate" :end="endDate" v-model="selectedDateRange" @change="onDateChange"> </uni-datetime-picker> </view> </template> <script> export default { data() { return { selectedDateRange: [], // 存储用户选择的时间范围 startDate: '', // 起始时间 endDate: '' // 结束时间 }; }, created() { this.setDefaultValue(); }, methods: { setDefaultValue() { const now = new Date(); // 当前时间对象 const year = now.getFullYear(); const month = String(now.getMonth() + 1).padStart(2, '0'); const day = String(now.getDate()).padStart(2, '0'); // 构造当天日期字符串 const today = `${year}-${month}-${day}`; // 将起始时间和结束时间均设为今天 this.startDate = today; this.endDate = today; // 如果需要,默认选中今天的日期范围 this.selectedDateRange = [today, today]; }, onDateChange(e) { console.log('Selected date range:', e); } } }; </script> ``` --- #### 关键点解析 1. **获取当前日期** 利用 `new Date()` 方法创建当前时间对象,并通过 `.getFullYear()`、`.getMonth()` 和 `.getDate()` 提取年份、月份和日数[^1]。注意月份是从零开始计数的,因此需加一处理。 2. **格式化日期** 使用 `String().padStart(2, '0')` 确保月份和日期始终为两位数形式,从而满足标准日期格式的要求。 3. **绑定默认值** 在组件初始化阶段调用 `setDefaultValue` 方法,将 `startDate` 和 `endDate` 均设置为当前日期。如果希望默认选中某个时间段,则可以直接赋值给 `v-model` 所绑定的数据变量 `selectedDateRange`。 4. **事件监听** 添加 `@change` 事件用于捕获用户的操作行为,并打印所选的时间范围以便调试或进一步处理。 --- #### 注意事项 - 若仅需单个日期而非区间,可将 `type` 属性改为 `"date"` 并调整数据结构。 - 验证逻辑可根据实际业务需求扩展,例如参照引用中的校验函数[^3]。 --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值