1.需求
输入框中输入数据,根据输入的结果模糊搜索数据库对应内容,实现模糊查询。
2.实现
输入框使用v-model双向绑定查询数据keyword。
<el-input v-model="keyword" placeholder="请输入关键字搜索" clearable></el-input> <el-button type="success" icon="el-icon-search" @click="search"></el-button>
由于输入框和显示结果的不再同一view下,所以在路由跳转时将搜索结果传递给显示结果的页面,这里用的query。
search函数:
searchresult.vue代码
在created函数中获取输入框传来的keyword
getdata(offset,limit)函数使用axios向后端根据keyword查询数据,其中offset和limit是分页查询的参数。
//请求数据库数据的方法 getdata(offset,limit){ this.axios.post('/php/search.php', qs.stringify({ offset: offset, limit: limit, keyword: this.keyword }), { headers: { 'content-type': 'application/x-www-form-urlencoded' } }).then((res) => { this.total = res.data.total this.resultlist = res.data.data }).catch((err) => { this.$message.error(err) })
获取数据成功后就会将数据存入resultlist数组中,只需循环遍历该数组就可以向前端展示查询结果了。
后端使用的是php写的,主要利用了sql语句的like来实现模糊查询。
后端search.php文件,将数据库连接基本信息改为自己的。
<?php$servername = "主机地址";$username = "账户";$password = "密码";$dbname = "数据库名称";// 创建连接$conn = new mysqli($servername, $username, $password, $dbname);// check connectionif ($conn->connect_error) { die("连接失败: " . $conn->connect_error);} $keyword = $_post['keyword'];//获取前端的参数 开始和结束numberif ( !isset( $_post['offset'] ) ) { echo 0; exit();};$offset = ( int )$_post['offset'];if ( !isset( $_post['limit'] ) ) { echo 0; exit();};$limit = ( int )$_post['limit'];//分页查询数据库$sql = "select * from posts where title like '%$keyword%' order by id desc limit $limit offset $offset";$result = $conn->query($sql);$sqlgetcount = "select count(*) cnt from posts where title like '%$keyword%'";$rescnt = $conn->query($sqlgetcount);$rescnt = $rescnt->fetch_assoc();$arr = array();if ($result->num_rows > 0) { while ( $row = $result->fetch_assoc() ) { array_push( $arr, $row );} //echo json_encode( $arr, json_unescaped_unicode ); echo json_encode(array_merge(array('data'=>$arr),array('total'=>(int)$rescnt['cnt']))); } else { echo 0;}mysqli_close( $conn );?>
注意sql语句:
select * from posts where title like '%$keyword%' order by id desc limit $limit offset $offset;
like后面应该使用 '%$keyword%‘传递参数,而不是 %' $keyword'%,算踩了一个坑吧。
然后这是根据输入的数据模糊查询标题,也就是数据段title的,可以改为查询其他的内容。
3.结果
以上就是vue怎么实现mysql数据库数据的模糊查询的详细内容。