草庐IT

【微信小程序】——案例:本地生活小程序首页前端页面

PaturNax 2023-03-28 原文

1. 新建项目

点击+

进入创建场景,选择对应的选项和自己的AppID

为了不见黄色警告热重载,可以选择关闭。

project.config.json项目的配置文件的setting配置添加如下:

"checkSiteMap":false

2. 配置首页

2.1 新建项目与梳理项目结构

点击app.json小程序项目的全局配置文件的pages配置中新建三个页面的目录,同时删掉默认创建的indexlogs路径,记得保存。

"pages/home/home",
"pages/message/message",
"pages/contact/contact"

2.2 配置导航栏

在app.json文件的window全局配置中修改导航栏名称的"navigationBarTitleText": "Weixin"为本地生活。

"navigationBarTitleText": "本地生活"

修改导航栏的默认背景颜色#fff#2b4b6b

"navigationBarBackgroundColor": "#2b4b6b",

改变文本颜色"navigationBarTextStyle":"black"由黑变白(也就这两种颜色选择

"navigationBarTextStyle":"white"

效果如下:

2.3 配置\(tabBar\)

由于我嫌找阿里图标太麻烦了,所以我选择直接拿别人的资料。

搜索黑马程序员公众号->黑马资源->2022资料下载->点击Web前端->找列表中的手把手快速带你开发微信小程序->找到微信小程序基础目录-领取资料中的day02。

链接:https://pan.baidu.com/s/1-2KMJ_lSHMI8JnzqUOy49w
提取码:p1op

把image文件夹放入到自己创建的项目主目录中。

app.json文件中配置tabBar项,修改三个页面对应的选中与未选中的图标,设置好各个的导航路径,最终配置如下。

  "tabBar": {
      "list": [{
          "pagePath": "pages/home/home",
          "text": "首页",
          "iconPath": "/images/tabs/home.png",
          "selectedIconPath": "/images/tabs/home-active.png"
      },{
        "pagePath": "pages/message/message",
        "text": "消息",
        "iconPath": "/images/tabs/message.png",
        "selectedIconPath": "/images/tabs/message-active.png"
      },{
        "pagePath": "pages/contact/contact",
        "text": "联系我",
        "iconPath": "/images/tabs/contact.png",
        "selectedIconPath": "/images/tabs/contact-active.png"
      }
    ]
  },

最终效果如下:

2.4 实现轮播图

2.4.1 获取数据

进入微信公众平台,登录后点击开发的开发管理

选择开发设置

选择服务器域名设置

在我们的request接口上添加黑马程序员提供的接口https://applet-base-api-t.itheima.net;

现在就可以看到微信开发者工具 右上侧详情的项目配置的域名信息了

获取Get接口为:https://applet-base-api-t.itheima.net/slides

进入pages/home/home.js文件,在data中定义数据数组swiperList

接着在onLoad函数下新增一个获取轮播图数据的方法

    //获取轮播图数据的方法
    getSwiperList(){
        wx.request({
          url: 'https://applet-base-api-t.itheima.net/slides',
          method:'GET',
          //定义一个名为res的形参,获取服务器返回的结果
          success:(res)=>{
            console.log(res);
          }
        })
    },

而我们清楚,当页面加载完成后才能显示出轮播图的结果,那么就需要修改onLoad函数对我们定义的上述方法进行加载。

    /**
     * 生命周期函数--监听页面加载
     */
    onLoad(options) {
        this.getSwiperList()
    },

可以看到控制台显示的后台信息为对象。

那么当我们成功调用函数时,也应该考虑把相应的数据加入到之前设置的swiperList数组中,通过在setdata中设定key为该数组,并对应的value为之前控制台得到的res对象中的data数组数据。

所以修改onLoad函数如下:

    //获取轮播图数据的方法
    getSwiperList(){
        wx.request({
          url: 'https://applet-base-api-t.itheima.net/slides',
          method:'GET',
          //定义一个名为res的形参,获取服务器返回的结果
          success:(res)=>{
            console.log(res);
            this.setData({
                swiperList:res.data
            })
          }
        })
    },

接着我们在调试器下面切换到AppData中,可以看到之前默认swiperList为空数组,也即没有存放数据。

后面保存后就有对应的数据,可以看到是相应的对象,有轮播图的图片链接。

2.4.2 渲染图层

利用微信自带的swiper轮播图组件中间镶嵌swiper-item组件,结合wx:for遍历与微信mustache语法(不就是插值表达式嘛?),另外要注意设置wx:key对应数据的id这确定不是Vue?)。

之后我们要在swiper-item里加入image组件,src为动态地址,所以还是要是使用mustache语法,由于用了wx:for可以获取item项,而我们之前可以知道之前swiperList存放的数据对象就有image键值对,因此可以写item.image

pages/home/home.wxml

<!-- 轮播图区域 -->
<swiper>
<swiper-item wx:for="{{swiperList}}" wx:key="id">
<image src="{{item.image}}"></image>
</swiper-item>
</swiper>

效果如下:

但是有点不太好看, 所以我们可以利用wxss(相当于微信的CSS独立样式文件)进行调整。

通过类选择器限定高度为350rpx,swiper 的 子类 image 强制高宽拓屏设100%

swiper {
    height: 350rpx;
}

swiper image {
    width:100%;
    height:100%;
}

然后为了让轮播图可以衔接的同时,可以显示小点表示位置变化,在home.wxml中的swiper修改成如下内容

<!-- 轮播图区域 -->
<swiper indicator-dots circular>
<swiper-item wx:for="{{swiperList}}" wx:key="id">
<image src="{{item.image}}"></image>
</swiper-item>
</swiper>

最终效果如下:

2.5 实现九宫格

2.5.1 获取数据

获取Get接口为:https://applet-base-api-t.itheima.net/categories
实现以下的步骤跟实现轮播图的步骤一致,所以接下来只写代码部分。

pages/home/home.js

    /**
     * 页面的初始数据
     */
    data: {
        //存放轮播图数据的数组
        swiperList:[],
        //存放九宫格数据的数组
        gridList:[],
    },

    /**
     * 生命周期函数--监听页面加载
     */
    onLoad(options) {
        this.getSwiperList()
        this.getGridList()
    },

    //获取九宫格数据的方法
    getGridList() {
        wx.request({
            url:'https://applet-base-api-t.itheima.net/categories',
            method : 'GET',
            success:(res)=>{
                console.log(res);
                this.setData({
                    gridList : res.data
                })
              }
        })
    },

2.5.2 渲染页面

要设置九宫格,就需要在外层容器里循环加入子容器,子容器之间限定对应的长宽并添加我们已有的九宫格数据的图标与文本,最后flex布局。

pages/home/home.wxml

<!-- 九宫格区域 -->
<view class="grid-list">
<view class="grid-item" wx:for="{{gridList}}" wx:key="id">
<image src="{{item.icon}}"></image>
<text>{{item.name}}</text>
</view>
</view>

pages/home/home.wxss

.grid-list{
    display:flex;
    /* 一行存不下,允许换行 */
    flex-wrap:wrap;
    /* 在item的基础上增加外部边框 */
    border-left: 1rpx solid #efefef;
    border-top: px solid #efefef;
}

.grid-item{
    width:33.33%;
    height:200rpx;
    /* 居中对齐,并保证组合为纵向布局 */
    display: flex;
    flex-direction: column;
    /* 横向和纵向的居中 */
    align-items: center;
    justify-content: center;
    /* 增加右侧和底部边框 */
    border-right: 1rpx solid #efefef;
    border-bottom: 1rpx solid #efefef;
    /* 为了不让边框挤压子容器图标,
    修改默认的content-box */
    box-sizing: border-box;
}

.grid-item image{
    /* 图片太大了 */
    width:60rpx;
    height:60rpx;
}

.grid-item text{
    font-size:24rpx;
    /* 文本与图片之间有距离 */
    margin-top: 10rpx;
}

最终效果如下:

2.6 实现底部图片布局

pages/home/home.wxml

<!-- 图片区域 -->
<view class="img-box">
<!-- widthFix在宽度不变的情况,高度自适应 -->
<image src="/images/link-01.png" mode="widthFix"></image>
<image src="/images/link-02.png" mode="widthFix"></image>
</view>

pages/home/home.wxss

.img-box{
    display: flex;
    /* 图片上下、左右有间距 */
    padding:20rpx 10rpx;
    /* 平分占满的img-box所留剩下右侧的空白区域 */
    justify-content: space-around;
}

.img-box image{
    width:45%;
}

最终效果如下:

3. 模板与配置的总结

3.1 总结图

3.2 注意事项

wx:ifhidden的区别就像v-ifv-show一样,前者是动态删除链接,后者只是样式的隐藏,如果要节省资源和经常使用可以用hidden

rpx在使用iphone6的模拟时进行换算更加方便,因为rpx就是把手机屏幕划分成750等份,即750rpx=375px->2rpx=1px

参考

视频链接(P36)

有关【微信小程序】——案例:本地生活小程序首页前端页面的更多相关文章

  1. ruby - 在 Ruby 程序执行时阻止 Windows 7 PC 进入休眠状态 - 2

    我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0

  2. ruby - 如何指定 Rack 处理程序 - 2

    Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack

  3. ruby - 在 Ruby 中编写命令行实用程序 - 2

    我想用ruby​​编写一个小的命令行实用程序并将其作为gem分发。我知道安装后,Guard、Sass和Thor等某些gem可以从命令行自行运行。为了让gem像二进制文件一样可用,我需要在我的gemspec中指定什么。 最佳答案 Gem::Specification.newdo|s|...s.executable='name_of_executable'...endhttp://docs.rubygems.org/read/chapter/20 关于ruby-在Ruby中编写命令行实用程序

  4. ruby - 使用 C 扩展开发 ruby​​gem 时,如何使用 Rspec 在本地进行测试? - 2

    我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当

  5. ruby-on-rails - Rails 应用程序之间的通信 - 2

    我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此

  6. ruby - 无法运行 Rails 2.x 应用程序 - 2

    我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby​​:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r

  7. ruby-on-rails - Rails 应用程序中的 Rails : How are you using application_controller. rb 是新手吗? - 2

    刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr

  8. ruby-on-rails - 如何在我的 Rails 应用程序 View 中打印 ruby​​ 变量的内容? - 2

    我是一个Rails初学者,但我想从我的RailsView(html.haml文件)中查看Ruby变量的内容。我试图在ruby​​中打印出变量(认为它会在终端中出现),但没有得到任何结果。有什么建议吗?我知道Rails调试器,但更喜欢使用inspect来打印我的变量。 最佳答案 您可以在View中使用puts方法将信息输出到服务器控制台。您应该能够在View中的任何位置使用Haml执行以下操作:-puts@my_variable.inspect 关于ruby-on-rails-如何在我的R

  9. ruby - 是否可以覆盖 gemfile 进行本地开发? - 2

    我们的git存储库中目前有一个Gemfile。但是,有一个gem我只在我的环境中本地使用(我的团队不使用它)。为了使用它,我必须将它添加到我们的Gemfile中,但每次我checkout到我们的master/dev主分支时,由于与跟踪的gemfile冲突,我必须删除它。我想要的是类似Gemfile.local的东西,它将继承从Gemfile导入的gems,但也允许在那里导入新的gems以供使用只有我的机器。此文件将在.gitignore中被忽略。这可能吗? 最佳答案 设置BUNDLE_GEMFILE环境变量:BUNDLE_GEMFI

  10. ruby - 检查是否通过 require 执行或导入了 Ruby 程序 - 2

    如何检查Ruby文件是否是通过“require”或“load”导入的,而不是简单地从命令行执行的?例如:foo.rb的内容:puts"Hello"bar.rb的内容require'foo'输出:$./foo.rbHello$./bar.rbHello基本上,我想调用bar.rb以不执行puts调用。 最佳答案 将foo.rb改为:if__FILE__==$0puts"Hello"end检查__FILE__-当前ruby​​文件的名称-与$0-正在运行的脚本的名称。 关于ruby-检查是否

随机推荐