做个小程序(三)——导航栏&搜索框

535 阅读8分钟

本文已参与「新人创作礼」活动,一起开启掘金创作之路

hello,项目都会新建了么,小程序页面都摸熟悉了的话我们就开始做一个小程序上手练一练吧! 我们接下来要做的就是做一个简易豆瓣电影小程序。

简易豆瓣小程序

既然要做我们就需要做好产品分析详细的来了解一下下究竟需要我们实现那些东西。

主界面

主界面由顶部导航栏,头部搜索栏,以及下面的三种影视列表组成。 一主界面

更多页面

更多页面和主页面的差不多,唯一的区别就是下面是单一的影视类别的影视,点击主页面的更多,就可以跳转到这里。

2】二更多

详情页面

详情页面石油顶部的导航栏,下面的影视介绍,中部的豆瓣标签以及底部的评论组成。

三详情

搜索

详情页面石油顶部的导航栏,以及一个搜索框,还有页面下部的影视搜索列表组成。

四搜索

历史搜索

详情页面石油顶部的导航栏,以及一个搜索框,还有下面的历史记录组成。 历史搜索

我们总览了所有的页面,我们现在可以进入到我们的新建小项目中为这几个项目新建一下各自的page页面,对应一下基本的项目构架。 项目页面

我们接下来可以实现一下豆瓣中通用的部分:

豆瓣导航栏实现

  • 在app.json中修改一下界面的导航字样 导航栏字样设置

豆瓣搜索框实现

既然说到搜索框那我们就不得不提出组件这个概念,组件是啥组件就像是你们家的火锅底料,他可以每次用每次取,不用每一次都自己去重新配置配方,哎我又想吃火锅了,也有点儿想我们程序中的函数,哪儿用到它就到哪引用。 话不多说开干!

组件定义

  • 首先创建一个总的文件夹:用来放组件我这里管它叫component位置一般在二级夹。

  • 组件的总夹

  • 然后再来创建一个文件夹放当前需要的组件 searchbar组件夹

  • 右击这个组件文件夹然后选择新建component起个合适的名字我这里的组件管它叫searchbar。 就会生成一些基本文件 右键选component 组件建成

  • 首先我们写出wxml基本样式:

<!--componests/searchbar/searchbar.wxml-->
<view class='searchbar'>
  <navigator class='search-navigator'></navigator>
  <view class='search-input-group'>
    <!-- 添加input事件 -->
    <input class='search-input' placeholder="搜一搜" ></input>
  </view>
</view>
  • 再用css给它美化:
.searchbar{
  background-color: #41be57;
  padding: 15rpx;
}
.search-navigator{
  width: 100%;
  height: 40px;  
  border-radius:10rpx;
  background-color: #ffffff;
  /* 转为64位颜色,可以节约内存空间 */
  /* 只有小图可以转!! */
  background-image: url("");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: 8%;  
}
.search-input-group{
  width: 100%;
  height: 60rpx;
  background-color: #fff;
  border-radius: 10rpx;
  padding: 10rpx 20rpx;
  box-sizing: border-box;
}
.search-input{
  min-height: 40rpx;
  height: 40rpx;
  font-size: 14px;
}

巨多的哪一行是我将图片转成了base64格式的代码,为了节省小程序占用空间。

绑定一下下事件

  • 我们再wxml里面做一下事件标记,添加事件:
<!--componests/searchbar/searchbar.wxml-->
<view class='searchbar'>
  <navigator wx:if="{{isnavigator}}" url='/pages/search/search' class='search-navigator'></navigator>
  <view wx:else class='search-input-group'>
    <!-- 添加input事件 -->
    <input class='search-input' placeholder="搜一搜" bindinput="onInputEvent"></input>
  </view>
</view>
  • 使用js绑定事件做渲染:
// componests/searchbar/searchbar.js
Component({
  /**
   * 组件的属性列表
   */
  properties: {
    isnavigator:{
      type:Boolean,
      value:false
    }
  },

  /**
   * 组件的初始数据
   */
  data: {

  },

  /**
   * 组件的方法列表
   */
  methods: {
    onInputEvent:function(event){
      // console.log(event);
  // 传参
      var value = event.detail.value;
      var detail = {"value":value}; 
      var options = {};
          // triggerevent(”event“)触发某一个事件
      this.triggerEvent("searchinput",detail,options);
    }
  }
})

  • 最后再来设置一下json配置文件的参数,让它显示:
{
  "component": true,
  "usingComponents": {}
}

现在就可以展示一下我们组件啦!

调用

我们在需要它的地方,给引用一下:

  • 引用操作: 修改json文件记得把路径填对哦:
{
    "usingComponents": {
      "searchbar": "/componests/searchbar/searchbar"
      }
}

wxml中写标识:

<searchbar isnavigator="{{true}}"></searchbar>

成果检验

导航和搜索框

好啦有问题的话,评论区留言,关注aFang每天会有很多的磕和你唠,哈哈哈哈!!!