zoukankan      html  css  js  c++  java
  • 前端非框架开发问题集

    Chrome控制台输出问题

    Added non-passive event listener to a scroll-blocking 'mousewheel' event. Consider marking event handler as 'passive' to make the page more responsive

    这是因为Chrome51版本以后,Chrome增加了新的事件捕获机制-Passive Event Listeners

    Passive Event Listeners就是告诉前页面内的事件监听器内部是否会调用preventDefault函数来阻止事件的默认行为,以便浏览器根据这个信息更好地做出决策来优化页面性能。当属性passive的值为true的时候,代表该监听器内部不会调用preventDefault函数来阻止默认滑动行为,Chrome浏览器称这类型的监听器为被动(passive)监听器。目前Chrome主要利用该特性来优化页面的滑动性能,所以Passive Event Listeners特性当前仅支持mousewheel/touch相关事件

    以前的事件捕获代码如下:

    <code>document.addEventListener("click", fn,false/true)</code>
    

    第三个参数决定了fn函数是在冒泡还是捕获阶段触发。
    现在第三个参数不但可以是布尔值,还可是一个对象

    <code>document.addEventListener(``"mousewheel"``, fn, {passive:` `true``})</code>
    

    React devtool在chrome下没办法使用

    某一天不知道怎么react devtool不能正常的显示react的自定义组件结构,*墙工具一时半会也用不了,网上找到通过编译生成需要的React DevTool插件

    react devtool官方包地址
    下载你电脑环境需要的压缩包,

    cnpm  install 
    npm run build:extension:chrome
    之后会出现以下内容,
    > @ build:extension:chrome C:UsershpDesktop
    eact-devtools-3.3.2
    > node ./shells/chrome/build
    
    ✓ Preparing build
    ✓ Building extension - temporary files in shellswebextensionuildchrome
    ✓ Unpacking extension - artifacts in shellschromeuild
    
    The Chrome extension has been built!
    You can test this build by running:
    
    # From the react-devtools root directory:
    yarn run test:chrome
    
    C:UsershpDesktop
    eact-devtools-3.3.2>yarn run test:chrome
    yarn run v1.3.2
    $ node ./shells/chrome/test
    

    react-devtools-3.2.1 > shells > chrome 下边多了build 以及下边的 unpacked文件夹,打开chrome://extensions/ 加载已解压的扩展程序指向unpacked文件 ok,记住不要删掉unpacked文件夹

    wepack工具下的问题

    Module build failed: Error: Plugin/Preset files are not allowed to export objects, only functions

      "dependencies": {
        "@babel/core": "^7.1.2",
        "@babel/plugin-transform-runtime": "^7.1.0",
        "@babel/preset-env": "^7.1.0",
        "@babel/runtime": "^7.1.2",
        "axios": "^0.18.0",
        "babel-loader": "^8.0.4",
        "babel-preset-react": "^6.24.1",
      },
      "devDependencies": {
        "clean-webpack-plugin": "^0.1.19",
        "webpack": "^3.0.0",
        "webpack-dev-server": "^2.9.7"
      }
    

    模块版本兼容性问题导致的上述问题

    "dependencies": {
        "@babel/core": "^7.1.2",
        "@babel/plugin-transform-runtime": "^7.1.0",
        "@babel/preset-env": "^7.1.0",
        "@babel/runtime": "^7.1.2",
        "axios": "^0.18.0",
        "babel-loader": "^8.0.4",
       
      },
      "devDependencies": {
        "@babel/preset-react": "^7.0.0",
        "clean-webpack-plugin": "^0.1.19",
        "webpack": "^3.0.0",
        "webpack-dev-server": "^2.9.7"
      }
    

    extract-text-webpack-plugin2.x到3.x的报错

    throw new _ValidationError2.default(ajv.errors, name);

    stackoverflow
    extract-text-webpack-plugin3.0配置

    Composes in Sass/Less

    composition is only allowed when selector is single :local class name not in "body :local(.box)"

    body{
        background: green;
        .box{
            height: 100px;
            200px;
            border:2px solid yellow;
            composes:bigBox from "./base.css";//报错因素
        }   
    }
    

    HMR模块热更新出现的错误

    Uncaught RangeError: Maximum call stack size exceeded
    at hotAddUpdateChunk (main.bundle.js:907)

    解决方案:删掉 webpack.config.js里面的 HotModuleReplacementPlugin()调用或者package.json的 --hot即可

    ES6模块导入导出问题

    You likely forgot to export your component from the file it's defined in, or you might have mixed up default and named imports.

    //index.js
    import BondItem from "./BondItem/BondItem.jsx";
    import FundItem from "./FundItem/FundItem.jsx";
    import StockItem from "./StockItem/StockItem.jsx";
    
    export  default {//去掉default之后不再报错,ES6语法报错
        BondItem,
        FundItem,
           StockItem
    }
    
    //main.js
    import {BondItem}
    

    Echarts数据表加载问题

    Component series.candlestick not exists. Load it first.

    Echart选择性模块导入
    参照上述文档缺啥导啥!

    npm模块安装出错

    This is related to npm not being able to find a file.

    483 verbose stack Error: ENOENT: no such file or directory, access 'D:ProjectPrivateMy_Financial_Control
    ode_modulesuglify-js
    ode_modulesyargs'
    484 verbose cwd D:ProjectPrivateMy_Financial_Control
    485 verbose Windows_NT 10.0.17134
    486 verbose argv "D:\Applications\node\node.exe" "C:\Users\hp\AppData\Roaming\npm\node_modules\npm\bin\npm-cli.js" "install" "codemirror" "--save"
    487 verbose node v8.11.4
    488 verbose npm  v6.4.1
    489 error path D:ProjectPrivateMy_Financial_Control
    ode_modulesuglify-js
    ode_modulesyargs
    490 error code ENOENT
    491 error errno -4058
    492 error syscall access
    493 error enoent ENOENT: no such file or directory, access 'D:ProjectPrivateMy_Financial_Control
    ode_modulesuglify-js
    ode_modulesyargs'
    494 error enoent This is related to npm not being able to find a file.
    495 verbose exit [ -4058, true ]
  • 相关阅读:
    好了伤疤,忘了疼,我又崴脚了
    征途 --从 5公里 前端 开始
    MVC 感触
    2公里
    又受伤了打篮球
    Unity Lighting,lighting map,probes
    UnityPostProcessing笔记
    unity HDRP和URP
    blender2.8 import fbx armature setting
    U3D资源加载框架迭代笔记
  • 原文地址:https://www.cnblogs.com/ziyoublog/p/10444204.html
Copyright © 2011-2022 走看看