vue+node全栈移动商城【5】-简单的筛选搜索功能

2019-02-12 admin

图片描述

现在咱们来实现一个简单的搜索功能。不需要数据库,更不需要存取数据,只是单纯的让搜索这个功能运行起来。

先来说一下,在前端的层面上,对于搜索大家不要想的太过于复杂。搜索当然可以做的非常复杂,例如百度。

但是搜索也可以非常简单。简单的说,无非就是你发送一个关键词到后端,后端对已有的数据进行一个筛选,如果有与关键词相同的,就认为找到结果,并将结果返回。

那么咱们现在就实现一个极简的搜索功能,只是用来验证思路。让同学们明白,前端+node,怎么实现一个筛选、搜索、查询的功能。

页面如下:

<div class="wrapDiv">
          <input type='text' class='leftDiv' ref='inputRef' placeholder="请输入" />
          <div class="rightDiv"> {{txt_data}} </div>
    </div>

    <van-button type="danger" @click="sendBtn">发送</van-button>
    <van-button type="danger" @click="getBtn">获取</van-button>

script部分:

sendBtn(){
                let _val = this.$refs.inputRef.value;
                // console.log( _val )

                axios.get('http://localhost:5678/node_a',{
                            params:{ v_data : _val }
                      });
          },
          getBtn(){
                axios.get('http://localhost:5678/node_b')
                      .then( _d=>{
                            console.log( _d.data );
                            this.txt_data = _d.data[0].name
                      })
          }

可能有同学会说,这不是跟上一篇文章的代码一样嘛? 是的呀,视图就是那个。但功能是不断的迭代、增加的。 看,接下来的nodeJs部分:, 以下代码都写在nodeJs中间件,api_dev.js中


先来准备一些假数据

var _xxObj = {
    arrs:[{
        id:'n1',
        name:'a_name',
        vals:'aaa'
    },{
        id:'n2',
        name:'b_name',
        vals:'bbb'
    },{
        id:'n3',
        name:'c_name',
        vals:'ccc'
    }]
}

再加一个变量,

// 保存过滤的结果,因为现在没有db
var _filterResult = null;

然后来一个过滤的函数,在node_a接口中调用

function filter( _val ){
    return _xxObj.arrs.filter( _g =>{
        return _g.vals === _val
    })
}
//这里有一些es6的语法,同学们自己去搞搞懂

// 第一个nodeJs接口,接收

app.get('/node_a', function(req, res){
    console.log( req.query.v_data );

    let _result = filter( req.query.v_data );

    _filterResult = _result.length !== 0 ? _result : [{id:'xxx', name:'没有结果'}]

    res.end();
});

这个node_a接口只做3件事, 1、把关键词从get方式的requ.query中接收到; 2、传入过滤方法filter中进行比较; 3、把结果存入公共变量 _filterResult 中;

这里当然存在全局变量污染,但我们不去管它


接下来是第二个接口,node_b

app.get('/node_b', function(req, res){
    res.send( _filterResult )
});

这个接口只做一件事,就是当它被请求的时候,把保存着过滤结果的变量_filterResult,返回到客户端。 //这里当然存在着各种操作流程上的问题。例如有没有值啊、加解密、报错啊,等等。我们都不去管它。

现在只要一件事,就是能把filter的结果返回,就ok。


为什么要做这一步呢? 因为后面的用户名已被注册、用户名不存在、用户登录、注册…等功能,其实都是这个思路。

在实际工作环境场景中,会有很多的判断、加解密、要求等等。

但抓住核心,【对于前端来讲,搜索在很多时候,其实就是比较字符串】

原文链接:https://segmentfault.com/a/1190000018129657

本站文章除注明转载外,均为本站原创或编译。欢迎任何形式的转载,但请务必注明出处。

转载请注明:文章转载自 JavaScript中文网 [https://www.javascriptcn.com]

本文地址:https://www.javascriptcn.com/read-53600.html

文章标题: vue+node全栈移动商城【5】-简单的筛选搜索功能

相关文章
vue+element-ui+slot-scope实现可编辑表格
1.咱开发拿到需求大多数是去网上找成型的组件,找不到再看原生的方法能否实现,大牛除外哈,大牛一般喜欢封装组件框架。 2.可编辑表格在后台管理系统还是比较常用的,因为比较流行框架element,iview都没有这个应用,所以考虑了两种方法,下...
2017-12-25
2015年JavaScript或“亲库而远框架”
2014年过去了,作为一个JavaScript开发者很难满怀信心的去“挽回”一个特定的库或技术,即便是强大的Angular,似乎也因为最近的一些事情而动摇。 2014年10月的ng-europe会议上,Angular开发者团队透露了一个关于...
2015-11-12
Node.js 2014这一年发生了什么
Node.js 的 2014 年充满了不幸和争议. 这一年 Noder 们经历了太多的伤心事, 经历了漫长的等待, 经历了沉重的分裂之痛. 也许 Noder 们不想回忆14年 Node.js land 发生的事情, 但正因为痛才更有铭记的价...
2015-11-12
国内外html5游戏引擎排行
一个好的HTML5游戏引擎,能够大大简化游戏的开发实现。 排名列表: Construct 2 ImpactJS EaselJS pixi.js Phaser GameMaker Three.js PlayCanvas Turbulenz ...
2015-11-12
详解HTML5游戏玩家流失原因
对任何类型的电子游戏来说,玩家流失都是一个无法回避的问题。玩家为什么离开游戏?近日,HTML5游戏设定师纳森·洛维托(Nathan Lovato)在游戏开发者网站Gamasutra撰写文章,解读了玩家离开游戏的16个理由。 HTML5游戏 ...
2015-11-12
YouTube正式默认使用HTML5视频播放器
YouTube视频网站现在默认使用HTML5播放器,这意味着更好的性能、 稳定性、 电池寿命和甚至是更好的安全性。现在用户通过Chrome、IE 11、Safari 8和Beta版本的Firefox进行浏览的时候都默认使用HTML5视频播放...
2015-11-12
Vue获取DOM元素样式和样式更改示例
在 vue 中用 document 获取 dom 节点进行节点样式更改的时候有可能会出现 ‘style’ is not definde的错误,这时候可以在 mounted 里用 $refs 来获取样式,并进行更改: &lt;template...
2017-03-13
Vue.js组件tab实现选项卡切换
本文实例为大家分享了vue插件tab选项卡的具体代码,供大家参考,具体内容如下 效果图: 代码如下: &lt;!DOCTYPE html&gt; &lt;html lang=&quot;en&quot;&gt; &lt;head&gt; ...
2017-03-13
HTML5的5个不错的开发工具推荐
HTML5规范终于在今年正式定稿,对于从事多年HTML5开发的人员来说绝对是一个重大新闻。数字天堂董事长,DCloud CEO王安也发表了文章,从开发者和用户两个角度分析了HTML对两个人群的优势。其实,关于HTML5的开发工具,我们以往的...
2015-11-12
HTML5凭什么可以代替Flash
本世纪初,全球网络建设仍处于早期阶段,发达国家网民刚刚在从窄带向宽带网络过渡。由于网络带宽、PC运算速度等因素限制,早期的网站基本以静态文字和图片内容为主。但随着宽带网络在全球范围快速普及,网民对内容的需求也不断变化。死板的文字加图片的网站...
2015-11-12
回到顶部