搜索框下侧提示信息等间距布局效果,自动换行

本文介绍如何使用CSS Flex布局和margin属性解决搜索框提示的等间距问题,通过具体代码示例展示了如何实现每个item两侧间距相等的效果。

UI

首先UI设计图长这样:
在这里插入图片描述
我们经常遇到的搜索框提示大都长这样,要怎么实现呢?

CSS

很自然的我们会用到flex布局,乍看上去以为是等间距justify-content:space-arround,但是实际操作起来往往会有问题。
如果使用了等间距,那么flex换行以后第二行如果是一个元素的话就会居中,那这样要怎么处理呢?

Solution

上一个办法行不通,那就只能另辟蹊径了。
我们注意到要求是每个item两侧的间距需要相等,那这样我们可以考虑使用margin来控制外边距。当然依旧是flex布局:

.ys-search-tips{
    padding: 8px 12px;
    .wrapper{
      display: flex;
      justify-content: flex-start;
      flex-wrap: wrap;

      .item{
        padding: 5px 8px;
        margin: 5px 8px;
        background: rgba(0,0,0,.06);
        border-radius:3px;
        color: #333333;
        font-size: 4vw;
      }
    }
  }

相应的html模板

<template>
  <div class="ys-search-tips">
    <div class="wrapper">
      <a class="item" href="javascript:;" @click="search(item.productId)" v-for="(item,index) of data" v-bind:key="index">
        {{item.name}}
      </a>
    </div>
  </div>
</template>

Effect

在这里插入图片描述

使用vue3 写一个页面,页面有一个叫编辑公式按钮;点击后,弹出一个页面,这个页面分左右两块A、B块;A块在左,B块在右;A块是树,带搜索功能;B块分上下三块B1/B2/B3块,B1+B2块占B块的90%,平均上下分布,B3块占B块的10%;B1是多功能输入框,占B块的一半,输入框支持上下滚动;输入来源分三块,第一块是左侧树,第二块是入由下方多功能按钮区带入,第三块是键盘输入,键盘输入只能数字和英文字符,自动带入的除外;B2是多功能按钮区,分别是+、-、*、/、if、else if、;、return、>、<、=、{、}、(、)、enter换行等点击按钮,按钮之间间隔5px,点击按钮B1输入框自动带入;其中点击换行时,B1输入框自动换行,且添加分割线,分割线上下间距1;B1输入框删除时,A块、B2 带入的只能整体删除,不能单个字符删除;删除时,当前行没有内容时,自动切换到上一行,且清除分割线;B3块有三个按钮靠右排列,分别是公式校验、确认、取消;A块树点击后,自动带入树的值到B1输入框内,展示时显示树的名称,返回的是树的id;B1用户输入只能数字和英文字符,自动带入的除外;B1输入框中的内容起始位正输入框的左上角,距边框5px;B1展示内容样式为随机颜色按钮,点击后,展示左插入、右插入、替换、删除操作,其中删除以右上角角标形式展示;点击B3块确认按钮时,以B1的内容以字符串且保留换行符的形式返回,回显时,需要根据所提供的字符串识别分块;
最新发布
06-21
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值