微信小程序——小程序开发经验总结(持续更新)_微信小程序开发心得-程序员宅基地

技术标签: 1024程序员节  微信小程序  前端  服务器  小程序  

微信小程序——开发经验总结(持续更新)

部署前端后,刷新页面没有更换效果

情境导入

  • vue项目打包生成了dist文件,然后进入了/www/server/nginx/html目录中,进行了文件更替

  • 重启nginx后,刷新页面,看新的页面效果

发现问题

  • 多次刷新后,仍没有看到在本地调试出的效果1

尝试解决

  • 我再次重启nginx,还是不行

  • 重启服务器,还是不行

  • 删掉前端项目文件,重新打包上传,还是不行

成功解决

  • 最后发现是因为浏览器的缓存问题!

  • 如何判断是浏览器缓存问题【当看到浏览器网页标题的icon图标更换成功,但是页面效果没有更换,那么大概率是服务器缓存问题

  • 可以使用安全管家快速清理浏览器缓存(这里使用的是腾讯安全管家)

image-20220928171154931

本地调试成功,上线却无法获取后台数据

情境引入

  • 本地调试成功,可以获取后台数据,上线或使用体验版时,却无法获取后台数据

发现问题

  • 上线前,忘记关闭

在这里插入图片描述

解决方法

  • 取消上面选项的勾选

报错解决

  • 当关闭了校验后,程序说该域名不合法,则需要到小程序后台 - 开发 - 开发设置 - 服务器域名中进行配置

注意

  • 还有下载的域名,上传文件的域名等等,都在这里配置!
image-20220928171154931

子组件无法使用Onload事件,但是可以用Onready进行替代

情境引入

  • Onload中,写入打印方法,但是不执行!

发现问题

  • 原来使用了自定义tabbar,将主页变成了tabbar的子组件!
  • 因此,我的三个主页都无法使用Onload事件

解决方法

  • Onready进行替代

前端传值给下一个页面,不能携带太多信息

前期构想

通过openid 获取到 用户上传的 信息档案

从后端获取的信息,再信息组装,进行显示即可!

为了方便后面的预览功能,将在这里把全部信息都组装好!

再通过 跳转时 把该猫咪信息携带过去

发现问题

  • 携带近20个属性的信息,用onload接收时,影响性能(所以:过多参数传不了,而且一般也不这样传。)
  • onready接收不了optionsonload可以接收

解决方法

  • 传一个id,跳过去接收id后,再去查详情就好了

自定义导航栏

发现问题

  • 电脑版可以同时看到全局导航栏自定义导航栏

解决方法

1、globalStyle里面的navigationBarTitleText进行全局设置名称

2、自定义导航栏也设置好导航栏名称

快速搜索方法

在这里插入图片描述

CSS开发笔记

权重问题

情境引入

当使用element等组件的时候,想改一下组件的样式,这个时候怎么去修改呢?

解决方法

1、快速修改:使用行内样式,直接修改!

2、使用css中 !important暴力修改(可以写在class中)

拓展1

项目中当有需求需要更改组件默认样式时,可以先在 Dom 树中找到该元素的类名,直接修改该类名下的属性,修改完成在后加! important 看效果能否实现。

.classname {
     
background: #333 !important;
}

如果没有实现效果,就要使用样式穿透的方式

sass/less使用样式穿透的方式为:/ deep /
父元素 / deep / 子元素

.parent /deep/ .children {
     
background: #333;
}

stylus的样式穿透的方式为:>>>
父元素 >>> 子元素

.parent >>> .children {
     
background: #333;
}

当然也可以在样式穿透下继续添加 ! important 强制修改样式。

附:

uniapp 强制修改原生组件的样式

/deep/  uni-swiper .uni-swiper-slide-frame{
     
		height: 115px !important;
	}

只加 !import 并没有生效 需要再加上 /deep/穿透 才能修改生效

空格问题

情境引入

flex布局没有学好,总是喜欢用空格去强制对齐盒子或者元素

但是使用组件的时候,底层早就用了white-space的CSS属性去进行处理,而且大多数组件都是normal属性:忽略多余的空白,只保留一个空白

解决方法

最终解决方法

学好div与flex【从根源解决问题】

在盒子内垂直居中

在盒子中实现垂直居中

设置顶部为0;

设置底部为0;

再让他自动设置边距,就可以让他自动分配盒子到两边的距离,就会自动垂直居中

.div {
    
  bottom: 0;
  top: 0;
  margin: auto;
}

ES6语法问题

值不会进行编译

在这里插入图片描述

这个单独的a咋理解呢?

es6里面讲过:直接放数或者字母,就相当于一个值,编译器不解析,直接跳过

简而言之:相当于没写,编译器自动跳过


gcc就是这么处理的:

在这里插入图片描述

测试网站——跳转网站 (godbolt.org)

心得分享

给在学的伙伴们提个建议,或者说要养成一个习惯

  1. 不同的页面最好都用不同的父文件夹
  2. 所有发的请求都封装好,最好和main平级用个文件夹放一起,并且根据当前的开发环境来判断url的不同情况(本地开发的)(线上测试的)(正式发布的)
  3. 多问多学多做自己的总结与记录,项目中遇到问题多打debugger,对自己的写的方法与回调或封装的API等多多用注释写好命名,多看看新的ui框架(PC的,APP的多多益善)
  4. 工作中和同事多沟通,多打好关系,下班了不要只想的玩游戏,偶尔看看哪怕自己懂的技术(温故而知新),自己最好能搞个demo试试不同的新依赖,新组件,新UI,新方法等。

(来自半路出家的前端哥们)

网站分享

开源前端动画库:
lottiefiles (https://lottiefiles.com)

每日三问

  1. 学后有思考吗?
  2. 有不看文档写一遍的习惯吗?
  3. 有每天写日报总结吗?
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/Pan_peter/article/details/127502440

智能推荐

class和struct的区别-程序员宅基地

文章浏览阅读101次。4.class可以有⽆参的构造函数,struct不可以,必须是有参的构造函数,⽽且在有参的构造函数必须初始。2.Struct适⽤于作为经常使⽤的⼀些数据组合成的新类型,表示诸如点、矩形等主要⽤来存储数据的轻量。1.Class⽐较适合⼤的和复杂的数据,表现抽象和多级别的对象层次时。2.class允许继承、被继承,struct不允许,只能继承接⼝。3.Struct有性能优势,Class有⾯向对象的扩展优势。3.class可以初始化变量,struct不可以。1.class是引⽤类型,struct是值类型。

android使用json后闪退,应用闪退问题:从json信息的解析开始就会闪退-程序员宅基地

文章浏览阅读586次。想实现的功能是点击顶部按钮之后按关键字进行搜索,已经可以从服务器收到反馈的json信息,但从json信息的解析开始就会闪退,加载listview也不知道行不行public abstract class loadlistview{public ListView plv;public String js;public int listlength;public int listvisit;public..._rton转json为什么会闪退

如何使用wordnet词典,得到英文句子的同义句_get_synonyms wordnet-程序员宅基地

文章浏览阅读219次。如何使用wordnet词典,得到英文句子的同义句_get_synonyms wordnet

系统项目报表导出功能开发_积木报表 多线程-程序员宅基地

文章浏览阅读521次。系统项目报表导出 导出任务队列表 + 定时扫描 + 多线程_积木报表 多线程

ajax 如何从服务器上获取数据?_ajax 获取http数据-程序员宅基地

文章浏览阅读1.1k次,点赞9次,收藏9次。使用AJAX技术的好处之一是它能够提供更好的用户体验,因为它允许在不重新加载整个页面的情况下更新网页的某一部分。另外,AJAX还使得开发人员能够创建更复杂、更动态的Web应用程序,因为它们可以在后台与服务器进行通信,而不需要打断用户的浏览体验。在Web开发中,AJAX(Asynchronous JavaScript and XML)是一种常用的技术,用于在不重新加载整个页面的情况下,从服务器获取数据并更新网页的某一部分。使用AJAX,你可以创建异步请求,从而提供更快的响应和更好的用户体验。_ajax 获取http数据

Linux图形终端与字符终端-程序员宅基地

文章浏览阅读2.8k次。登录退出、修改密码、关机重启_字符终端

随便推点

Python与Arduino绘制超声波雷达扫描_超声波扫描建模 python库-程序员宅基地

文章浏览阅读3.8k次,点赞3次,收藏51次。前段时间看到一位发烧友制作的超声波雷达扫描神器,用到了Arduino和Processing,可惜啊,我不会Processing更看不懂人家的程序,咋办呢?嘿嘿,所以我就换了个思路解决,因为我会一点Python啊,那就动手吧!在做这个案例之前先要搞明白一个问题:怎么将Arduino通过超声波检测到的距离反馈到Python端?这个嘛,我首先想到了串行通信接口。没错!就是串口。只要Arduino将数据发送给COM口,然后Python能从COM口读取到这个数据就可以啦!我先写了一个测试程序试了一下,OK!搞定_超声波扫描建模 python库

凯撒加密方法介绍及实例说明-程序员宅基地

文章浏览阅读4.2k次。端—端加密指信息由发送端自动加密,并且由TCP/IP进行数据包封装,然后作为不可阅读和不可识别的数据穿过互联网,当这些信息到达目的地,将被自动重组、解密,而成为可读的数据。不可逆加密算法的特征是加密过程中不需要使用密钥,输入明文后由系统直接经过加密算法处理成密文,这种加密后的数据是无法被解密的,只有重新输入明文,并再次经过同样不可逆的加密算法处理,得到相同的加密密文并被系统重新识别后,才能真正解密。2.使用时,加密者查找明文字母表中需要加密的消息中的每一个字母所在位置,并且写下密文字母表中对应的字母。_凯撒加密

工控协议--cip--协议解析基本记录_cip协议embedded_service_error-程序员宅基地

文章浏览阅读5.7k次。CIP报文解析常用到的几个字段:普通类型服务类型:[0x00], CIP对象:[0x02 Message Router], ioi segments:[XX]PCCC(带cmd和func)服务类型:[0x00], CIP对象:[0x02 Message Router], cmd:[0x101], fnc:[0x101]..._cip协议embedded_service_error

如何在vs2019及以后版本(如vs2022)上添加 添加ActiveX控件中的MFC类_vs添加mfc库-程序员宅基地

文章浏览阅读2.4k次,点赞9次,收藏13次。有时候我们在MFC项目开发过程中,需要用到一些微软已经提供的功能,如VC++使用EXCEL功能,这时候我们就能直接通过VS2019到如EXCEL.EXE方式,生成对应的OLE头文件,然后直接使用功能,那么,我们上篇文章中介绍了vs2017及以前的版本如何来添加。但由于微软某些方面考虑,这种方式已被放弃。从上图中可以看出,这一功能,在从vs2017版本15.9开始,后续版本已经删除了此功能。那么我们如果仍需要此功能,我们如何在新版本中添加呢。_vs添加mfc库

frame_size (1536) was not respected for a non-last frame_frame_size (1024) was not respected for a non-last-程序员宅基地

文章浏览阅读785次。用ac3编码,执行编码函数时报错入如下:[ac3 @ 0x7fed7800f200] frame_size (1536) was not respected for anon-last frame (avcodec_encode_audio2)用ac3编码时每次送入编码器的音频采样数应该是1536个采样,不然就会报上述错误。这个数字并非刻意固定,而是跟ac3内部的编码算法原理相关。全网找不到,国内音视频之路还有很长的路,音视频人一起加油吧~......_frame_size (1024) was not respected for a non-last frame

Android移动应用开发入门_在安卓移动应用开发中要在活动类文件中声迷你一个复选框变量-程序员宅基地

文章浏览阅读230次,点赞2次,收藏2次。创建Android应用程序一个项目里面可以有很多模块,而每一个模块就对应了一个应用程序。项目结构介绍_在安卓移动应用开发中要在活动类文件中声迷你一个复选框变量

推荐文章

热门文章

相关标签