<template> <!-- <div class="bg-grey-lighten-3 tw-w-full tw-h-[60px]"></div> --> <!-- color="grey-lighten-3" --> <v-card class="mx-auto !tw-z-10" max-width="" height="60"> <v-layout> <v-app-bar scroll-behavior="elevate" color="white" density="default"> <v-app-bar-title v-if="!showSearch"> <a href="/"><v-img src="/mobile/index-logo.png" alt="canrud" width="100" height="40" /></a> </v-app-bar-title> <template v-slot:append> <v-btn icon v-if="!showSearch"> <v-icon @click="showSearch = !showSearch">mdi-magnify</v-icon> </v-btn> <v-app-bar-nav-icon @click="drawer = !drawer" v-if="!drawer"></v-app-bar-nav-icon> <v-app-bar-nav-icon @click="drawer = !drawer" v-if="drawer" icon="mdi-window-close"></v-app-bar-nav-icon> </template> <div class="tw-h-[36px] tw-w-[300px] ml-8" v-if="showSearch"> <v-text-field dense density="compact" height="24" label="Search keyword" hide-details="auto" variant="solo" append-inner-icon="mdi-close" @click:appendInner="handleClick" @keydown="handleKeyDown" v-model="input"> </v-text-field> </div> </v-app-bar> <v-navigation-drawer width="512" v-model="drawer" location="right" temporary floating> <v-list density="compact" nav> <v-list-item to="/" title="Home" value="home" @click="handleTabClick" color="blue-darken-1"> </v-list-item> <v-divider></v-divider> <v-list-item to="/products" title="Products" value="Products" @click="handleTabClick" color="blue-darken-1"></v-list-item> <v-divider></v-divider> <v-list-item to="/about" title="About" value="about" @click="handleTabClick" color="blue-darken-1"></v-list-item> <v-divider></v-divider> <v-list-item to="/contact" title="Contact" value="contact" @click="handleTabClick" color="blue-darken-1"></v-list-item> <v-divider></v-divider> <v-list-item title="Blog" value="blog" color="blue-darken-1"> <a href="http://blog.canrud.com/" target="" title="Blog">Blog</a> </v-list-item> </v-list> </v-navigation-drawer> </v-layout> </v-card> <!-- <v-container> <v-row class="tw-m-auto tw-flex tw-items-center"> <v-col cols="2" class="pa-0 tw-h-[64px]"> <router-link to="/"><v-img src="/logo.jpg" alt="canrud" /></router-link> </v-col> <v-col cols="6" md="8" class="px-0"> <v-text-field label="Search keyword" hide-details="auto" variant="solo" append-inner-icon="mdi-magnify" @click:appendInner="handleClick" @keydown="handleKeyDown" v-model="input" > </v-text-field> </v-col> <v-col cols="4" md="2" class="px-0"> <v-btn variant="text" @click="dialogStore.updateDialog(true)" color="blue-darken-2 mt-4" >Concat Us </v-btn> </v-col> </v-row> </v-container> --> <ContactDialog /> </template> <script setup lang="ts"> import { ref, watchEffect } from 'vue' import { useProductListStore } from '@/stores/product_list' import { useRouter } from 'vue-router' import { useDialogStore } from '@/stores/dialog' import { useCategoryStore } from '@/stores/category' import { useDisplay } from 'vuetify' const drawer = ref(false) const showSearch = ref(false) const productStore = useProductListStore() const categoryStore = useCategoryStore() const input = ref() const router = useRouter() const handleKeyDown = (e: any) => { if (e.keyCode == 13) { categoryStore.updateDisplay(!input.value) productStore.updateKeyword(input.value) productStore.updatePageNo(1) router.push('/products') } } const handleClick = () => { showSearch.value = false } const handleTabClick = () => { categoryStore.updateDisplay(true) productStore.updateKeyword('') } watchEffect(() => { input.value = productStore.keyword }) onMounted(() => { // 获取url的参数 const url = window.location.href const index = url.indexOf('?') if (index !== -1) { const params = url.slice(index + 1).split('&') const obj: any = {} params.forEach((item) => { const arr = item.split('=') obj[arr[0]] = arr[1] }) // 获取dialog的状态 if (obj.flag) { dialog.updateDialog(true) } if (obj.keyword) { productStore.updateKeyword(obj.keyword) } } }) </script> <style lang="scss" scoped> .tabs { background-color: #1f88e5; } .active :deep { .v-tab__slider { bottom: 3px; } } </style>