|                                                                                                                     |  | <template>  <view class="search-input-container">    <view class="search-box">      <view class="search-icon" @click="handleSearch">        <uv-icon name="search" size="20"></uv-icon>      </view>      <input         class="search-input"         type="text"         :placeholder="placeholder"        v-model="inputValue"        @input="handleInput"        @confirm="handleSearch"      />
      <text class="search-text" v-if="showSearchButton" @click="handleSearch">{{ searchButtonText }}</text>    </view>  </view></template>
<script>export default {  name: 'SearchInput',  props: {    placeholder: {      type: String,      default: '请输入搜索内容'    },    showSearchButton: {      type: Boolean,      default: true    },    searchButtonText: {      type: String,      default: '搜索'    },    value: {      type: String,      default: ''    }  },  data() {    return {      inputValue: this.value    }  },  watch: {    value(newVal) {      this.inputValue = newVal    },    inputValue(newVal) {      this.$emit('input', newVal)    }  },  methods: {    handleInput(e) {      this.inputValue = e.detail.value || e.target.value      this.$emit('input', this.inputValue)    },    handleSearch() {      // console.log('搜索的数值为', this.inputValue);
      this.$emit('search', this.inputValue)    }  }}</script>
<style lang="scss" scoped>.search-input-container {  padding: 20rpx 30rpx;}
.search-box {  display: flex;  align-items: center;  background-color: #fff;  border-radius: 37rpx;  box-shadow: 0rpx 3rpx 6rpx 0rpx rgba(0,0,0,0.16);   padding: 0 19rpx 0 29rpx;  height: 79rpx;    // transition: border-color 0.3s ease;
    // &:focus-within {
  //   border: 1rpx solid $primary-color;
  //   border-color: #c70019;
  // }
}
.search-icon {  margin-right: 7rpx;  display: flex;  align-items: center;  justify-content: center;}
.search-input {  flex: 1;  border: none;  outline: none;  background: transparent;  font-size: 28rpx;  color: $secondary-text-color;  height: 100%;    &::placeholder {    color: #999;  }}
.search-text {  color: $primary-color;  font-size: 28rpx;}
</style>
 |