|
|
- <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>
|