zoukankan      html  css  js  c++  java
  • 每日思考(2020/08/31)

    题目概览

    • HTML5标准提供了哪些新的API?
    • 当一个元素被设置为浮动后,它的display值变为什么
    • 分别写出数组的交集、并集、差集、补集这四个方法
    • 对图片防盗链的理解

    题目解答

    HTML5标准提供了哪些新的API

    • 两个选择器API

      document.querySelector()
      document.querySelectAll()
      
    • 地理定位API

      getCurrrentPosition()
      
    • 多媒体API

      <video></video>
      <audio></audio>
      
    • 拖放

      <div ondrop="drop(event)" ondragover="allowDrop(event)"></div>
      <div draggable="true" ondragstart="drag(event)"></div>
      
    • 文件

      window.requestFileSystem()
      
    • XHR2

      var xhr = new XMLHttpRequest();
      xhr.open("POST", "@Url.Action("Upload")")
      
    • 本地存储API

      localStorage
      sessionStorage
      
    • canvas

      <canvas id="myCanvas" width="200" height="100">
      
    • svg

      <svg xmlns="http://www.w3.org/2000/svg" version="1.1">
         <circle cx="100" cy="50" r="40" stroke="black" stroke-width="2" fill="red" />
      </svg>
      

    当一个元素被设置为浮动后,它的display值变为什么

    • 一个元素被设为绝对定位或者浮动后,其display计算值就变为了block,尽管其表现形式和inline-block类似——包裹内部元素且不超出包含块的特性。

    • 按照如下方式在控制台尝试可验证:

      var span = document.createElement('span');
      document.body.appendChild(span);
      console.log(window.getComputedStyle(span).display);//inline
      span.style.float = 'left';
      console.log(window.getComputedStyle(span).display);//block
      

    分别写出数组的交集、并集、差集、补集这四个方法

    • 使用 filterconcat 来计算

      var a = [1,2,3,4,5]
      var b = [2,4,6,8,10]
      //交集
      var c = a.filter(function(v){ return b.indexOf(v) > -1 })
      //差集
      var d = a.filter(function(v){ return b.indexOf(v) == -1 })
      //补集
      var e = a.filter(function(v){ return !(b.indexOf(v) > -1) })
              .concat(b.filter(function(v){ return !(a.indexOf(v) > -1)}))
      //并集
      var f = a.concat(b.filter(function(v){ return !(a.indexOf(v) > -1)}))
      
    • 对 Array 进行扩展

      var a = [1,2,3,4,5]
      var b = [2,4,6,8,10]
      //数组功能扩展,数组迭代函数
      Array.prototype.each = function(fn){
        fn = fn || Function.K;
         var a = [];
         var args = Array.prototype.slice.call(arguments, 1);
         for(var i = 0; i < this.length; i++){
             var res = fn.apply(this,[this[i],i].concat(args));
             if(res != null) a.push(res);
         }
         return a;
      };
      
      //数组是否包含指定元素
      Array.prototype.contains = function(suArr){
        for(var i = 0; i < this.length; i ++){
            if(this[i] == suArr){
                return true;
            }
         }
         return false;
      }
      
      //不重复元素构成的数组
      Array.prototype.uniquelize = function(){
         var ra = new Array();
         for(var i = 0; i < this.length; i ++){
            if(!ra.contains(this[i])){
                ra.push(this[i]);
            }
         }
         return ra;
      };
      
      //两个数组的交集
      Array.intersect = function(a, b){
         return a.uniquelize().each(function(o){return b.contains(o) ? o : null});
      };
      
      //两个数组的差集
      Array.minus = function(a, b){
         return a.uniquelize().each(function(o){return b.contains(o) ? null : o});
      };
      
      //两个数组的补集
      Array.complement = function(a, b){
         return Array.minus(Array.union(a, b),Array.intersect(a, b));
      };
      
      //两个数组并集
      Array.union = function(a, b){
         return a.concat(b).uniquelize();
      };
      
      /*使用*/
      console.log("a与b的交集:", Array.intersect(a, b));
      console.log("a与b的差集:", Array.minus(a, b));
      console.log("a与b的补集:", Array.complement(a, b));
      console.log("a与b的并集:", Array.union(a, b));
      
    • ES6

      var a = [1,2,3,4,5]
      var b = [2,4,6,8,10]
      var sa = new Set(a);
      var sb = new Set(b);
      // 交集
      let intersect = a.filter(x => sb.has(x));
      // 差集
      let minus = a.filter(x => !sb.has(x));
      // 补集
      let complement  = [...a.filter(x => !sb.has(x)), ...b.filter(x => !sa.has(x))];
      // 并集
      let unionSet = Array.from(new Set([...a, ...b]));
      

    对图片防盗链的理解

    • 盗链 是指在自己的页面上展示一些并不在自己服务器上的内容。通常的做法是通过技术手段获得它人服务器上的资源地址,绕过别人的资源展示页面,直接在自己的页面上向最终用户提供此内容。
    • 防盗链 就是防止盗链。
    • http 协议中,如果从一个页面跳到另一个页面,header 字段里面会带个 Referer。图片服务器通过检测 Referer 是否来自规定域名,来进行防盗链。
  • 相关阅读:
    源代码搭建应用(一)——动手搭建自己的计算集群系统
    [转载]Ubuntu 14.04中root 密码忘记解决方法
    如何用路由器改成WiFi Pineapple系统镜像网络流量
    DELPHI黑客编程(一):正向后门原理实现
    OpenWrt 路由器过滤广告的N种方法
    Windows 10 上强制Visual Studio以管理员身份运行
    DB2修改表字段
    Git Fast-forward提交
    C#(去、过滤)掉字符中的换行符
    VS读取文件或写入文件时出现中文乱码问题
  • 原文地址:https://www.cnblogs.com/EricZLin/p/13593610.html
Copyright © 2011-2022 走看看