【微信小程序低代码开发】二,在实操中化解小程序的代码组成

2024-02-24 18:20

本文主要是介绍【微信小程序低代码开发】二,在实操中化解小程序的代码组成,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上一章我们对项目的结构有了一定的了解,大家会发现,小程序项目的文件,分离的很彻底,每个文件都有自己的作用,那么接下来让我们深入去理解这些文件

文章目录

    • 一,最小的小程序文件组成
    • 二,与web区别
      • 2.1 WXML和HTML
      • 2.2 WXSS和CSS
      • 2.3 JS
    • 三,配置文件JSON
      • 3.1 app.json
        • 3.1.1 创建新页面Pages
        • 3.1.2 修改项目页面首页
        • 3.1.3 app.json其他全局配置
      • 3.2 project.config.json
      • 3.3 sitemap.json

一,最小的小程序文件组成

当我们创建一个小程序项目时,开发者工具会自动帮我们创建一些默认的结构,但为了去了解小程序执行时的步骤,我们可以删除这些结构,只留下pages文件
如下所示:
在这里插入图片描述
这时候我们ctrls保存编译一下,会发现它会出现一行报错
app.json: app.json 未找到
也就是说编译时,小程序会先去找我们的app.json文件

  1. 那么现在我们创建一个app.json文件在根目录下,在里面放上JSON文件的格式,一个大括号包起来,里面不写东西。
    再保存编译:
    报错如下
    在这里插入图片描述

  2. app.json里的pages是什么?里面配置的是我们页面的路径,
    那么我们给它填上一个路径
    在这里插入图片描述
    这就在告诉编译器,我们的一个页面的路径,这时候编译器并没有报错,但它警告说没有找到我们的app.js文件

  3. 在根目录在再添加app.js文件,里面什么都不放,这时候编译成功,这就是一个最小小程序的项目。

app.js文件是小程序项目的入口文件,在编译时,编译器配置全局后,就会去找我们根目录下的app.js文件,通过里面的APP()函数,创建出一个小程序实例

二,与web区别

2.1 WXML和HTML

WXML全名WeiXin Markup Language,是微信小程序独有的文件格式

它与HTML的区别有几点

  1. 标签名
    在HTML 中,有div span img a
    而在WXML中,有view text imaga navigation
    view在微信小程序中其实就是充当div的角色,,作为块级元素进行布局
    text 一般存放文本,作为WXML中的行内元素
    image用法和img一致,包含图片
    navigation标签就是超链接标签,存放链接

  2. 属性节点
    在img中,是用属性src存放链接,而在image中,是用url存放

<img src="#">
<image url="#">
  1. 多了类似vue的语法
    什么,没学过?没事,照样学!
    其实就将渲染和逻辑分离的MVVM模式,在网页的开发中,我们经常通过JS操作DOM,当项目越来越大时,你的代码会充斥着非常多交互逻辑和程序的各种状态变量,这样结构上不是很友好,而MVVM开发模式就是提倡不让JS直接操控DOM,JS只需要作为一个管理者,区别出状态,然后通过模板语法(react、vue)来表述状态与界面结构的关系即可
    小程序框架也是用到这个思路,如下:
    WXML可以这样写:
<text>{{msg}}</text>

JS无需获取变量

this.setData{{ msg: "Hello World"}}

这种我们称为数据绑定,通过双大括号的方式,将一个变量绑定到页面,我们可以直接在JS对其进行修改,现在可以先了解一下

2.2 WXSS和CSS

WXSS全名为WeiXin Style Sheets,其具有CSS大部分特性,微信小程序在此之上,做了些修改和扩充

  1. 新增尺寸单位,在CSS样式中,开发中需要手动用rem对不同屏幕大小进行换算,而WXSS新增的rps可以自动换算像素单位
  2. 全局样式
    也就是app.wxss文件,与之前app开头文件一样,里面说设置的样式,会对所有页面生效,也就是全局样式,而各页面的样式文件,只对该页面生效
  3. WXSS只支持部分选择器
    类选择器,id选择器,标签选择器,并集选择器,::after::before

2.3 JS

与用户的交互我们交由JS脚本文件完成,利用之前提到的数据绑定,如我们获取用户的点击状态然后进行响应:

<view>{{msg}}</view>
<button bindtap="click">点击有好事发生</button>

bindtap进行事件绑定,当点击后会在该页面对应的Page中找到对应事件处理函数

Page({click: function(){this.setData({ msg: "Hello World"})	}
)

这些事件和组件的使用后面会边应用边讲解

在项目结构中,也有各个层次的JS文件

  • 如前面提到的app.js文件,是整个项目的入口文件,小程序将调用里面的App函数,将小程序实例化并运行
  • 各页面文件夹下的的.js文件,调用里面的Page函数,实例化并运行页面
  • 还有一个utils文件夹下的普通JS文件,这是功能模块文件,常常用来封装公共的函数和属性

三,配置文件JSON

3.1 app.json

3.1.1 创建新页面Pages

上面说到的app.json就是配置全局的静态数据,像是里面的pages属性,里面存放页面的路径

上一章我们讲过在一个页面文件中需要有四个不同类型的文件,但是我们不需要一一创建

只需要在pages文件夹上创建一个文件夹,然后右键新建的文件夹选择新建page

在这里插入图片描述
填入我们想要的文件名,如index,我们会发现,它会自动帮我们新建那四个文件,同时,在app.json中,开发者工具会自动在pages中添加新建页面的路径
在这里插入图片描述

3.1.2 修改项目页面首页

小程序会将全局配置文件app.json下pages的第一个页面默认为首页,如果需要更改首页,只需在首页的路径换到pages的第一行即可

{"pages"["pages/list/list","pages/index/index"]
}
3.1.3 app.json其他全局配置
  • window 配置小程序所有页面的顶部
    用于设置状态栏,导航条,标题,窗口背景色等
    这里介绍几个比较常用的
  1. navigationBarBackgroundColor 设置值为十六进制的颜色值,设置导航仪背景颜色
  2. navigationBarTextStyle 标题颜色设置,不过只支持whiteblack
  3. navigationBarTitleText 标题文本设置

其他属性可以在微信的官方文档获取

例子展示:

{"pages": ["pages/index/index","pages/list/list"],"window": {"navigationBarBackgroundColor": "#fff","navigationBarTextStyle": "black","navigationBarTitleText": "第一个小程序"}
}

在这里插入图片描述

  • tabBar 底部tab栏设置
    主要用到的属性有
  1. list 底部列表,最少放俩个,最多放五个
  2. color 文字默认颜色
  3. selectedColor 被选择是文字颜色
  4. backgroundColor tab背景颜色
    颜色需要使用十六进制颜色值

展示:

  "tabBar": {"list": [{"pagePath": "pages/index/index","text": "首页"},{"pagePath": "pages/list/list","text": "目录"}],"color": "#fff","selectedColor": "#999","backgroundColor": "#111"}

在这里插入图片描述
全局配置的属性很多,这里先做一个了解

3.2 project.config.json

项目的配置文件,项目的公共配置会写在里面,如项目名字,项目的appid,源码目录等等
其实还有一个文件叫project.private.config.json,里面会写项目的个人配置

3.3 sitemap.json

配置小程序及其页面是否允许微信索引,微信会有爬虫来爬我们小程序,当用户搜索时,如果我们允许索引,我们的小程序就可以被搜索到

今天小程序的代码组成到这就结束啦,如果觉得有帮助的话,可以持续关注下牛牛的更新,
感谢您的支持!

债见~

这篇关于【微信小程序低代码开发】二,在实操中化解小程序的代码组成的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/742947

相关文章

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

Java实现状态模式的示例代码

《Java实现状态模式的示例代码》状态模式是一种行为型设计模式,允许对象根据其内部状态改变行为,本文主要介绍了Java实现状态模式的示例代码,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来... 目录一、简介1、定义2、状态模式的结构二、Java实现案例1、电灯开关状态案例2、番茄工作法状态案例