首页
关于叶子
Search
1
Win10突然出现不能连接共享打印机一例
310,089 阅读
2
[经验存档] 微星(MSI)B150M-Pro-VD Plus安装系统蓝屏一例
181,656 阅读
3
Laravel“高并发”导致数据“统计”异常一例
71,213 阅读
4
[iOS|Xcode]iOS-App自定义启动页制作(uniapp适用)
52,058 阅读
5
[Windows]查看连接过的WIFI密码
47,948 阅读
代码
分享
琐事
MySQL
数码
前端
MacOS
软件
Windows
PHP
GoLang学习
登录
Search
标签搜索
Laravel
PHP
Windows
Laravel-Admin
Vue
uniapp
CSS
前端
chartjs
HTML
微信
小程序
web
MacOS
App
iOS
工具
Golang
微服务
高并发
Yesr00
累计撰写
64
篇文章
累计收到
7
条评论
首页
栏目
代码
分享
琐事
MySQL
数码
前端
MacOS
软件
Windows
PHP
GoLang学习
页面
关于叶子
搜索到
34
篇与
的结果
2025-02-07
PHP版本演进与核心特性解析:从PHP 5到PHP 8的技术革新
探索PHP从5.3到8.3的版本演进,解析各版本核心特性与性能优化。涵盖命名空间、JIT编译器、类型系统等关键改进,提供版本升级建议与最佳实践,助您掌握现代PHP开发。
2025年02月07日
5,522 阅读
0 评论
0 点赞
2025-02-06
DcatAdmin 中 $form->saving() 与 $form->saved() 的区别及实战示例
核心区别方法触发时机可修改表单值数据持久化状态$form->saving()表单提交后,数据保存到数据库前触发✔️ 生效尚未保存到数据库$form->saved()表单数据成功保存到数据库后触发❌ 需手动处理已生成完整模型数据使用场景对比1. $form->saving() - 保存前干预典型场景:修改即将存储的原始数据 特点:直接修改表单输入值,最终会随表单提交保存到数据库$form->saving(function (Form $form) { // 直接修改表单字段值(生效) $form->input('price', $form->input('price') * 0.8); // 自动打8折 // 或通过模型属性修改(需模型已实例化) if ($form->model()->exists) { $form->model()->slug = Str::slug($form->title); } });2. $form->saved() - 保存后处理典型场景:基于已存储数据的后续操作 注意:此时修改模型数据需手动保存,且要避免无限循环$form->saved(function (Form $form) { // 获取已保存的模型实例 $model = $form->model(); // 修改数据需显式保存 $model->update_count += 1; $model->save(); // 必须手动调用 // 典型场景:关联操作/异步任务 Log::info('数据更新', $model->toArray()); dispatch(new SendUpdateNotification($model)); });常见问题示例Q:为什么在 saved() 中修改数据无效?错误示范:$form->saved(function (Form $form) { $form->model()->price = 100; // 未调用 save() });修正方案:$form->saved(function (Form $form) { $model = $form->model(); $model->price = 100; $model->save(); // 必须显式保存 });最佳实践建议数据预处理优先使用 saving()字段格式化自动生成 slug计算衍生字段值后置操作使用 saved()写入操作日志清理缓存触发异步任务避免循环触发 在 saved() 中保存模型时添加条件判断:$form->saved(function (Form $form) { if ($form->model()->isDirty()) { // 检查是否有修改 $form->model()->save(); } });通过合理运用这两个回调,可以实现表单数据处理的全生命周期管理。关键要牢记:saving 管存前加工,saved 管存后跟进。
2025年02月06日
4,637 阅读
0 评论
0 点赞
2025-01-07
【CSS系统化学习】- 基础部分
# CSS基础入门:样式引入与核心概念---## 一、CSS的三种引入方式### 1. 内联样式 **适用场景**:快速调试单个元素的样式 **语法**:直接在HTML标签中使用`style`属性 **示例**: ```html内联样式示例文本``` **缺点**:难以维护,无法复用样式规则。---### 2. 内部样式表 **适用场景**:单页面样式管理 **语法**:在HTML文件的``标签内添加``块 **示例**: ```html body { background-color: #f0f0f0; } h1 { color: blue; text-align: center; } 内部样式表示例标题 ``` **优点**:页面级样式隔离,避免污染全局样式。---### 3. 外部样式表 **适用场景**:多页面共享样式 **语法**:通过``标签引入独立的`.css`文件 **示例**: **styles.css**: ```css .container { max-width: 1200px; margin: 0 auto; } ``` **index.html**: ```html 内容区域 ``` **优势**: - 代码复用性强 - 便于团队协作 - 浏览器缓存优化性能---## 二、样式优先级规则 | 引入方式 | 优先级 | 作用范围 | |----------------|--------|----------| | 内联样式 | 最高 | 单个元素 | | 内部样式表 | 中 | 当前页面 | | 外部样式表 | 低 | 全局 |**冲突解决**: 当多个样式规则冲突时,优先级遵循: `!important > 内联样式 > ID选择器 > 类选择器 > 元素选择器`---## 三、最佳实践建议 1. **开发环境**:使用外部样式表便于维护 2. **生产环境**:压缩CSS文件(如`styles.min.css`) 3. **调试技巧**:通过浏览器开发者工具实时修改样式
2025年01月07日
5,631 阅读
0 评论
0 点赞
2025-01-07
【CSS系统化学习】- 大纲
最近失业,苦于之前的所有码农知识都是根据各种教程自学而来的,打算系统化学习一下。CSS 学习大纲基础部分1. 引入CSS 内联样式 内部样式表 外部样式表 2. CSS选择器 元素选择器 类选择器 ID选择器 属性选择器 伪类选择器 伪元素选择器 3. 盒模型 边框(border) 填充(padding) 边距(margin) 4. 文本属性 字体系列(font-family) 字体大小(font-size) 字体粗细(font-weight) 文字颜色(color) 行高(line-height) 文本对齐方式(text-align) 文本装饰(text-decoration) 文本转换(text-transform) 5. 背景 背景颜色(background-color) 背景图片(background-image) 背景重复(background-repeat) 背景位置(background-position) 背景附着(background-attachment) 中级部分6. 定位 浮动(float) 清除浮动(clear) 定位模式(position) 静态定位(static) 相对定位(relative) 绝对定位(absolute) 固定定位(fixed) z-index 7. Flexbox布局 显示Flex容器(display: flex;) 主轴方向(flex-direction) 换行(flex-wrap) 对齐项目(justify-content, align-items, align-self) 8. Grid布局 创建Grid容器(display: grid;) 列模板(grid-template-columns) 行模板(grid-template-rows) 区域模板(grid-template-areas) 自动填充(auto-fill) 自动适应(auto-fit) 网格间距(gap) 9. 过渡与动画 过渡效果(transition) 关键帧动画(@keyframes) 动画属性(animation) 10. 响应式设计 媒体查询(media queries) 视口单位(vw, vh, vmin, vmax) 图片响应式(max-width: 100%; height: auto;) 高级部分11. 变量 CSS变量(--variable-name) 12. 样式继承 了解哪些属性会继承 13. 特殊选择器 后代选择器 子选择器(>) 相邻兄弟选择器(+) 通用兄弟选择器(~) 14. 高级布局技术 多列布局(column-count, column-gap) 形状外边距(shape-outside) 分区布局(container-type, container-name) 15. 性能优化 减少重绘和回流 使用合适的单位 最小化样式的使用
2025年01月07日
7,013 阅读
0 评论
0 点赞
2025-01-07
Dcat-Admin 2.x表单使用select和input进行表单联动一例
前言这个场景是最近在写一个兼职项目的时候用到的一个场景。但是由于select数量太多使用when的话不太合适当前场景。而用自带的load或者loads无法实现正常的赋值,改了各种接口格式不是undefined就是报错。在不想改源码的情况下,使用了当前方法。使用代码示例-以widget form为例$this->select('user_no','用户编号')->options(User::query()->pluck('user_no','id'))->script( " $('select[name=\"station_no\"]').on('change',function(e){ var station_no = $(this).val(); $.ajax({ url:'/admin/name_by_no', method:'GET', data:{q:station_no}, success:(res)=>{ console.log('success',res); $('input[name=\"name\"]').val(res.text); }, fail:(err)=>{ console.log('err',err); } }); })" ); $this->text('name','姓名')->readonly(true); 总结通过上述方法,实现了在选中select选项后对text进行赋值的一个演示。
2025年01月07日
4,436 阅读
0 评论
0 点赞
1
2
3
...
7