首页 |  我的博客 |  查看该博主内容分类 | 

随笔分类 -  常见问题解决方案

摘要:解决办法 假设A表有一个多对多properties字段,通过A表远程查询properties的名称 qs = A.objects.filter(properties__name=xxx) 更复杂的: A表有一个外键字段version连接B表,B表有一个多对多字段properties,通过A表远程查询 阅读全文
posted @ 2023-12-08 19:34 Z哎呀 阅读(16) 评论(0) 推荐(0) 编辑
摘要:前提:嵌套字段是主表的一个字段 解决办法 class ChildAlarmSerializer(serializers.ModelSerializer): class Meta: model = models.ChildAlarm fields = [ 'id', 'name', ... ] cla 阅读全文
posted @ 2023-12-08 11:08 Z哎呀 阅读(5) 评论(0) 推荐(0) 编辑
摘要:解决办法、 降级importlib-metadata pip install importlib-metadata==4.13.0 阅读全文
posted @ 2023-12-04 20:53 Z哎呀 阅读(110) 评论(0) 推荐(0) 编辑
摘要:解决办法 降级urllib3到2版本以下 pip install 'urllib3<2' 阅读全文
posted @ 2023-11-27 15:44 Z哎呀 阅读(133) 评论(0) 推荐(0) 编辑
摘要:原因 el-row是通过设置padding-left和padding-right腾出的空间,然后通过margin-left、margin-right设置负值保持位置不变 解决办法 上述el-row的设计逻辑理论是可行的,但结果是我把margin去掉(即设置为0:margin: 0)反而正常了,原因暂 阅读全文
posted @ 2023-11-14 09:32 Z哎呀 阅读(730) 评论(1) 推荐(1) 编辑
摘要:解决办法 注意文件路径是文件夹要以/斜杠结尾 正确:/path/to/data/ 错误:/path/to/data 示例: location /data { alias /path/to/data/; autoindex on; } 阅读全文
posted @ 2023-11-01 10:27 Z哎呀 阅读(19) 评论(0) 推荐(0) 编辑
摘要:解决办法 在el-radio或el-checkbox上添加属性(给标签设置一个class): display: flex; /* 用于对齐文本 */ 在el-radio或el-checkbox的选项标签上添加属性: /deep/ .el-radio__label{ white-space: norm 阅读全文
posted @ 2023-10-31 11:41 Z哎呀 阅读(2521) 评论(0) 推荐(0) 编辑
摘要:原因 可能组件考虑的是样式会写在class,而没有考虑到会写在style的情况 解决办法 将样式写在class上,特别是height属性,会导致这个问题出现。 阅读全文
posted @ 2023-09-27 17:15 Z哎呀 阅读(55) 评论(0) 推荐(0) 编辑
摘要:解决办法 正确写法:calc(100vh - #{$height}) √ 错误写法:calc(100vh - $height) × 阅读全文
posted @ 2023-09-25 10:51 Z哎呀 阅读(34) 评论(0) 推荐(0) 编辑
摘要:原因 importlib-metadata从5.0开始不支持该功能。 解决办法 将版本降到5.0以下,如4.13.0 pip install importlib-metadata==4.13.0 或 pip install importlib-metadata<5 阅读全文
posted @ 2023-09-21 16:12 Z哎呀 阅读(644) 评论(0) 推荐(0) 编辑
摘要:## 解决思路 1. 使用IDE进行Debug调试,将代码的每一步执行是否按照预期执行; 2. 找到为按预期执行的那一步,分析代码的判断是否准确,查看相关变量的值是否正确。 附Pycharm Debug快捷键: `F7` 进入到代码(详细到每一步,如循环的每一次循环) `F8` 按代码小块查看(一般 阅读全文
posted @ 2023-09-06 17:38 Z哎呀 阅读(8) 评论(0) 推荐(0) 编辑
摘要:> 本例讨论的是带有属性属性传递的情况,即有等号后面这段的情况。如果没有,v-slot:slotName是可以正常获取到的(虽然\$slots显示为空,但\$slots.slotName还是能正确获取到的,可通过设计一个点击按钮,打印log的方式验证) ## 解决办法 slot标签有一个特点,当没有 阅读全文
posted @ 2023-09-05 09:58 Z哎呀 阅读(19) 评论(0) 推荐(0) 编辑
摘要:## 原因 1. 在wangEditor中,textarea与提示文字不是一起的(提示文字独立于textarea,不是父子关系)。我通过去除父级元素样式继承还是一样对不齐,因而需要进行微调; 2. 原min-height最小高度虽然是100%,但问题还是出现了,需要调小。 ## 解决办法 在wang 阅读全文
posted @ 2023-08-21 14:31 Z哎呀 阅读(372) 评论(0) 推荐(0) 编辑
摘要:可能原因 更新的数据跟源数据不是同一个,即不是同一个引用 解决办法 最稳妥的办法,可通过拿到源数据取索引的方式进行数据的更新,如: 有一个源数据叫:originData 那么如果在更新时,通过this.originData[index].time = newValue的方式进行更新,而不是item. 阅读全文
posted @ 2023-08-17 19:33 Z哎呀 阅读(801) 评论(0) 推荐(0) 编辑
摘要:## 示例 假如我想获取一个字段去重的结果,类似excel中对一列执行数据去重得到那一列的内容,示例如下: ~~~python result1 = Book.objects.values_list('title', flat=True).distinct() print(result1) # 上述例 阅读全文
posted @ 2023-08-08 16:02 Z哎呀 阅读(260) 评论(0) 推荐(0) 编辑
摘要:## 示例 `v-model.number`即限制输入数字(原理是每次输入都会转化为数字,非数字则会丢弃) **还有更多,如:** `v-model.trim`:去除首尾空格。可以避免误输入一些不能看见的首尾空格。 `v-model.lazy`:延迟更新。默认情况下,v-model 在每次输入时都会 阅读全文
posted @ 2023-08-07 19:05 Z哎呀 阅读(245) 评论(0) 推荐(0) 编辑
摘要:## 原因 1. 关联的表中没有查询对象关联的数据; 2. 注意关联的数据是多条还是单条。 ## 解决办法 1. 给查询对象关联的表中增加该对象关联的数据; 2. 单条直接`.name`(点用法),多条先`.all()`再逐条`.name` 阅读全文
posted @ 2023-08-07 09:21 Z哎呀 阅读(93) 评论(0) 推荐(0) 编辑
摘要:## 原因分析 解构赋值大括号{}与原箭头函数的大括号冲突,导致无法正常解析 ## 解决办法 - 错误示例 ~~~js () => {...object1, ...object2} ~~~ - **正确示例** ~~~js () => ({...object1, ...object2}) // 即将 阅读全文
posted @ 2023-08-04 09:00 Z哎呀 阅读(19) 评论(0) 推荐(0) 编辑
摘要:## 原因 rules没有设置trigger校验触发的方式 ## 解决办法 设置上即可,如: ~~~js rules: { username: [ {required: true, message: '该项不能为空', trigger: 'blur'} // trigger: 'blur' ], . 阅读全文
posted @ 2023-07-31 17:36 Z哎呀 阅读(129) 评论(0) 推荐(0) 编辑
摘要:## 解决办法 工具-选项-键盘和鼠标 鼠标-向右按钮-Paste the clipboard contents 选择-将选定的文本自动复制到剪贴板 阅读全文
posted @ 2023-07-28 10:31 Z哎呀 阅读(130) 评论(0) 推荐(0) 编辑

// let homeEle = document.querySelector('body') // homeEle.setAttribute('id', 'particles-js') // /* ---- particles.js config ---- */ // particlesJS("particles-js", { // "particles": { // "number": { // "value": 380, // "density": { // "enable": true, // "value_area": 800 // } // }, // "color": { // "value": "#ffffff" // }, // "shape": { // "type": "circle", // "stroke": { // "width": 0, // "color": "#000000" // }, // "polygon": { // "nb_sides": 5 // }, // "image": { // "src": "img/github.svg", // "width": 100, // "height": 100 // } // }, // "opacity": { // "value": 0.5, // "random": false, // "anim": { // "enable": false, // "speed": 1, // "opacity_min": 0.1, // "sync": false // } // }, // "size": { // "value": 3, // "random": true, // "anim": { // "enable": false, // "speed": 40, // "size_min": 0.1, // "sync": false // } // }, // "line_linked": { // "enable": true, // "distance": 150, // "color": "#ffffff", // "opacity": 0.4, // "width": 1 // }, // "move": { // "enable": true, // "speed": 6, // "direction": "none", // "random": false, // "straight": false, // "out_mode": "out", // "bounce": false, // "attract": { // "enable": false, // "rotateX": 600, // "rotateY": 1200 // } // } // }, // "interactivity": { // "detect_on": "canvas", // "events": { // "onhover": { // "enable": true, // "mode": "grab" // }, // "onclick": { // "enable": true, // "mode": "push" // }, // "resize": true // }, // "modes": { // "grab": { // "distance": 140, // "line_linked": { // "opacity": 1 // } // }, // "bubble": { // "distance": 400, // "size": 40, // "duration": 2, // "opacity": 8, // "speed": 3 // }, // "repulse": { // "distance": 200, // "duration": 0.4 // }, // "push": { // "particles_nb": 4 // }, // "remove": { // "particles_nb": 2 // } // } // }, // "retina_detect": true // }); // var count_particles, stats, update; // stats = new Stats; // stats.setMode(0); // stats.domElement.style.position = 'absolute'; // stats.domElement.style.left = '0px'; // stats.domElement.style.top = '0px'; // document.body.appendChild(stats.domElement); // count_particles = document.querySelector('.js-count-particles'); // update = function() { // stats.begin(); // stats.end(); // if (window.pJSDom[0].pJS.particles && window.pJSDom[0].pJS.particles.array) { // count_particles.innerText = window.pJSDom[0].pJS.particles.array.length; // } // requestAnimationFrame(update); // }; // requestAnimationFrame(update);