360搜索

jsonp跨域访问接口
虽然js是受到同源策略,但是引用js文件,img,css文件是不会受到限制的。我们可以利用标签的src属性这个特点,动态的创建script标签,通过src属性发送相关的请求,请求的时候,返回回来的数据,是一个函数调用,会被当作JS代码执行,所以只要我们提前声明好和返回的函数调用同名的函数,那么在数据请求成功之后,

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        * {
            padding: 0;
            margin: 0;
            list-style-type: none;
        }
        .box {
            width: 250px;
            height: 40px;
            border: 1px solid #ccc;
            border-radius: 5px;
            position: absolute;
            top: 100px;
            left: 50%;
            margin-left: -125px;
        }
        .box input {
            height: 100%;
            width: 100%;
            border: none;
            text-indent: 10px;
            outline: none;
        }
        .box ul {
            position: absolute;
            width: 100%;
            top: 40px;
            left: 0;
            border: 1px solid #ccc;
            border-top: none;
            display: none;
        }
        .box ul li {
            height: 40px;
            line-height: 40px;
            border-bottom: 1px solid #ccc;
            text-indent: 10px;
        }
    </style>
</head>
<body>
    <div class='box'>
        <input type="text" placeholder="请输入搜索内容" value="">
        <ul></ul>
    </div>

  <script type="text/javascript" src="art-template.js"></script>

  <script type="text/template" id="tpl">
      {{each result}}
      <li>
        <a href="https://www.so.com/s?ie=utf-8&fr=none&src=home-sug-store&q={{$value.word}}" id="">{{$value.word}}</a>
      </li>
      {{/each}}
  </script>

  <script type="text/javascript">
      window.onload = function () {

                var input = document.querySelector('input');
        var ul = document.querySelector('ul');

        //将这个作为window的属性,这样的话在哪里都可以调用的到
        window.suggest_so = function (data) {
          ul.innerHTML = template('tpl',data);
        }

        input.onkeyup = function () {
          var val = this.value;
          //当输入的值为空的时候隐藏ul
          if(val == "") {
            ul.style.display = "none";
          } else {
            ul.style.display = "block";
          }
          //创建一个script标签,让这个标签发出请求
          var script = document.createElement('script');
          script.src = 'https://sug.so.360.cn/suggest?callback=suggest_so&encodein=utf-8&encodeout=utf-8&format=json&fields=word&word='+val;
          document.body.appendChild(script);
          document.body.removeChild(script);
        }
      }
  </script>

</body>
</html>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 五十三:请解释 JavaScript 中 this 是如何工作的。1.方法调用模式当一个函数被保存为一个对象的属性...
    Arno_z阅读 625评论 0 2
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,288评论 19 139
  • AJAX 原生js操作ajax 1.创建XMLHttpRequest对象 var xhr = new XMLHtt...
    碧玉含香阅读 3,378评论 0 7
  • 这是朋友借给我的一本很好的书籍,很多涉及我刚刚考过的知识点。而且富有多种案例与经典书籍的核心思想。粗粗翻过一遍,我...
    余师师阅读 976评论 0 3
  • 如何避免职场冲突 文/宁国涛 人的精力和时间都是非常有限的,避免职场冲突,与同事相处得和谐,才能够集中精力认真工作...
    宁让职场更给力阅读 2,915评论 72 68