每日思考(2019/12/12)

题目概览

  • HTML5的文件离线储存怎么使用,工作原理是什么?
  • CSS选择器有哪些?哪些属性可以继承?
  • 写一个方法把下划线命名转成大驼峰命名

题目解答

HTML5的文件离线储存怎么使用,工作原理是什么

  • 使用

    • 在页面头部加入一个manifest的属性

      <!DOCTYPE HTML>
      <html manifest = "cache.manifest">
      ...
      </html>
    • cache.manifest文件

      CACHE MANIFEST
      #v0.11
      CACHE: 
      //表示需要离线存储的资源列表,由于包含manifest文件的页面将被自动离线存储,所以不需要把页面自身也列出来
      js/app.js
      css/style.css
      
      NETWORK:
      //表示在它下面列出来的资源只有在在线的情况下才能访问,他们不会被离线存储,所以在离线情况下无法使用这些资源。不过,如果在CACHE和NETWORK中有一个相同的资源,那么这个资源还是会被离线存储,也就是说CACHE的优先级更高
      resourse/logo.png
      
      FALLBACK:
      //表示如果访问第一个资源失败,那么就使用第二个资源来替换他,比如上面这个文件表示的就是如果访问根目录下任何一个资源失败了,那么就去访问offline.html
      / /offline.html
  • 原理

    • 在线的情况下,浏览器发现html头部有manifest属性,它会请求manifest文件,如果是第一次访问app,那么浏览器就会根据manifest文件的内容下载相应的资源并且进行离线存储。如果已经访问过app并且资源已经离线存储了,那么浏览器就会使用离线的资源加载页面,然后浏览器会对比新的manifest文件与旧的manifest文件,如果文件没有发生改变,就不做任何操作,如果文件改变了,那么就会重新下载文件中的资源并进行离线存储;离线的情况下,浏览器就直接使用离线存储的资源

    • 如果服务器对离线的资源进行了更新,那么必须更新manifest文件之后这些资源才能被浏览器重新下载,如果只是更新了资源而没有更新manifest文件的话,浏览器并不会重新下载资源,也就是说还是使用原来离线存储的资源

    • 对于manifest文件进行缓存的时候需要十分小心,因为可能出现一种情况就是你对manifest文件进行了更新,但是http的缓存规则告诉浏览器本地缓存的manifest文件还没过期,这个情况下浏览器还是使用原来的manifest文件,所以对于manifest文件最好不要设置缓存

    • 浏览器在下载manifest文件中的资源的时候,它会一次性下载所有资源,如果某个资源由于某种原因下载失败,那么这次的所有更新就算是失败的,浏览器还是会使用原来的资源

    • 在更新了资源之后,新的资源需要到下次再打开app才会生效,如果需要资源马上就能生效,那么可以使用window.applicationCache.swapCache()方法来使之生效,出现这种现象的原因是浏览器会先使用离线资源加载页面,然后再去检查manifest是否有更新,所以需要到下次打开页面才能生效

      //对于HTML5中离线存储对象window.applicationCache
      1.oncached:当离线资源存储完成之后触发这个事件
      2.onchecking:当浏览器对离线存储资源进行更新检查的时候会触发这个事件
      3.ondownloading:当浏览器开始下载离线资源的时候会触发这个事件
      4.onprogress:当浏览器在下载每一个资源的时候会触发这个事件,每下载一个资源就会触发一次。
      5.onupdateready:当浏览器对离线资源更新完成之后会触发这个事件
      6.onnoupdate:当浏览器检查更新之后发现没有资源更新的时候触发这个事件

CSS选择器有哪些?哪些属性可以继承?

  • 选择器

    选择器 例子 例子描述 CSS
    .class .intro 选择 class="intro" 的所有元素。 1
    #id #firstname 选择 id="firstname" 的所有元素。 1
    * * 选择所有元素。 2
    element p 选择所有元素。 1
    element,element div,p 选择所有元素和所有元素。 1
    element element div p 选择元素内部的所有元素。 1
    element>element div>p 选择父元素为元素的所有元素。 2
    element+element div+p 选择紧接在元素之后的所有元素。 2
    [attribute] [target] 选择带有 target 属性所有元素。 2
    [attribute=value] [target=_blank] 选择 target="_blank" 的所有元素。 2
    [attribute~=value] [title~=flower] 选择 title 属性包含单词 "flower" 的所有元素。 2
    [attribute|=value] [lang|=en] 选择 lang 属性值以 "en" 开头的所有元素。 2
    :link a:link 选择所有未被访问的链接。 1
    :visited a:visited 选择所有已被访问的链接。 1
    :active a:active 选择活动链接。 1
    :hover a:hover 选择鼠标指针位于其上的链接。 1
    :focus input:focus 选择获得焦点的 input 元素。 2
    :first-letter p:first-letter 选择每个元素的首字母。 1
    :first-line p:first-line 选择每个元素的首行。 1
    :first-child p:first-child 选择属于父元素的第一个子元素的每个元素。 2
    :before p:before 在每个元素的内容之前插入内容。 2
    :after p:after 在每个元素的内容之后插入内容。 2
    :lang(language) p:lang(it) 选择带有以 "it" 开头的 lang 属性值的每个元素。 2
    element1~element2 p~ul 选择前面有元素的每个元素。 3
    [attribute^=value] a[src^="https"] 选择其 src 属性值以 "https" 开头的每个 元素。 3
    [attribute$=value] a[src$=".pdf"] 选择其 src 属性以 ".pdf" 结尾的所有 元素。 3
    [attribute*=value] a[src*="abc"] 选择其 src 属性中包含 "abc" 子串的每个 元素。 3
    :first-of-type p:first-of-type 选择属于其父元素的首个元素的每个元素。 3
    :last-of-type p:last-of-type 选择属于其父元素的最后元素的每个元素。 3
    :only-of-type p:only-of-type 选择属于其父元素唯一的元素的每个元素。 3
    :only-child p:only-child 选择属于其父元素的唯一子元素的每个元素。 3
    :nth-child(n) p:nth-child(2) 选择属于其父元素的第二个子元素的每个元素。 3
    :nth-last-child(n) p:nth-last-child(2) 同上,从最后一个子元素开始计数。 3
    :nth-of-type(n) p:nth-of-type(2) 选择属于其父元素第二个元素的每个元素。 3
    :nth-last-of-type(n) p:nth-last-of-type(2) 同上,但是从最后一个子元素开始计数。 3
    :last-child p:last-child 选择属于其父元素最后一个子元素每个元素。 3
    :root :root 选择文档的根元素。 3
    :empty p:empty 选择没有子元素的每个元素(包括文本节点)。 3
    :target #news:target 选择当前活动的 #news 元素。 3
    :enabled input:enabled 选择每个启用的 元素。 3
    :disabled input:disabled 选择每个禁用的 元素 3
    :checked input:checked 选择每个被选中的 元素。 3
    :not(selector) :not(p) 选择非元素的每个元素。 3
    ::selection ::selection 选择被用户选取的元素部分。 3
  • 可以继承的属性

    • 字体系列属性:

      属性 描述
      font 组合字体
      font-family 规定元素的字体系列
      font-weight 设置字体的粗细
      font-size 设置字体的尺寸
      font-style 定义字体的风格
      font-variant 设置小型大写字母的字体显示文本
      font-stretch 允许你使文字变宽或变窄。所有主流浏览器都不支持
      font-size-adjust 为某个元素规定一个 aspect 值
    • 文本系列属性

      属性 描述
      text-indent 文本缩进
      text-align 文本水平对齐
      line-height 行高
      word-spacing 增加或减少单词间的空白(即字间隔)
      letter-spacing 增加或减少字符间的空白(字符间距)
      text-transform 控制文本大小写
      direction 规定文本的书写方向
      color 文本颜色
    • 元素可见性:visibility

    • 表格布局属性:caption-side、border-collapse、border-spacing、 empty-cells、table-layout

    • 列表属性:list-style-type、list-style-image、list-style-position、list-style

    • 生成内容属性:quotes

    • 光标属性:cursor

    • 页面样式属性:page、page-break-inside、windows、orphans

    • 声音样式属性:speak、speak-punctuation、speak-numeral、speak-header、 speech-rate、volume、voice-family、pitch、pitch-range、stress、richness、、azimuth、elevation

写一个方法把下划线命名转成大驼峰命名

//方式一:转为数组操作
function toCamelCase(str) {
    if (typeof str !== 'string') {
        return str;
    }
    return str.split('_').map(item => item.charAt(0).toUpperCase() + item.substr(1, item.length)).join('');
}
//方式二:正则匹配
function toCamelCase(str) {
    str = str.replace(/(\w)/, (match, $1) => `${$1.toUpperCase()}`)
    while (str.match(/\w_\w/)) {
        str = str.replace(/(\w)(_)(\w)/, (match, $1, $2, $3) => `${$1}${$3.toUpperCase()}`)
    }
    return str
}

猜你喜欢

转载自www.cnblogs.com/EricZLin/p/12032373.html