分类 前端 下的文章

vscode折叠/展开所有区域代码快捷键


  1. 折叠所有区域代码的快捷键:先按下ctrl+K,再按下ctrl+0; (注意这个是零,不是欧)
  2. 展开所有折叠区域代码的快捷键:先按下ctrl+K,再按下ctrl+J ;
  3. 自动格式化代码的快捷键:先按下ctrl+K,再按下ctrl+f;

当前端Vue打包代码部署项目到服务器后出现404错误


一、Vue项目部署步骤

在前后端分离的开发模式下,前端项目独立部署通常涉及以下步骤:

1.构建项目:Vue项目构建后生成一系列静态文件。
2.上传文件:使用scp命令将构建好的文件上传至服务器的web容器指定静态目录。

scp dist.zip user@host:/xx/xx/xx

3.配置Web服务器:以Nginx为例,配置服务器以指向静态文件目录。

server {
  listen 80;
  server_name www.xxx.com;
  location / {
    index /data/dist/index.html;
  }
}


第一次使用uniapp的vue-cli命令方式踩坑记录


关于使用uniapp的vue-cli命令式运行会报错,特别收藏记录了几种问题


报错:node-sass和sass-loader
node 版本14.17.1,需要适配响应的node-sass和sass-loader版本

参考链接:https://blog.csdn.net/m0_67392126/article/details/126113751

解决方案:
1、先卸载:
npm uninstall node-sass
npm uninstall sass-loader
2、安装:
npm install --save-dev node-sass@4.14.1
npm install --save-dev sass-loader@7.3.1
npm install --save-dev node-sass@4.14.1
npm install --save-dev sass-loader@7.3.1


报错:PostCSS plugin autoprefixer requires PostCSS 8

参考链接:https://blog.csdn.net/candyyii/article/details/109055180

解决方案:
npm i postcss-loader autoprefixer@8.0.0


关于elementUI表单验证validate时click方法blur失效的解决办法


有时候我们页面上会有多个表单,且表单中绑定的字段有重复,这时会出现blur无法激活表单的正常验证,这时候就需要用于key,只需要给el-form-item标签,添加key属性即可,如1:

<el-form-item label="联系方式" prop="contact_information" :key="Math.random()">
    <el-input v-model="itemForm.contact_information" placeholder="请输入联系方式"></el-input>
</el-form-item>

有的时候验证红色文字出现后,然后给表单赋值但是还是通不过,其实是有值的,也可以用这种绑定key的方法,如2:

<el-form-item label="视频封面:" prop="videoBanner" v-if="videoParams.videoPath" :key="Math.random()">
  <div class="coverCont">
    <el-image fit="contain" class="topicCover" :src="videoParams.videoBanner" v-if="videoParams.videoBanner">
    </el-image>
    <el-button type="primary" @click="getCovers" style="width: 98px">选择封面</el-button>
    <el-input style="display: none;" v-model="videoParams.videoBanner" />
  </div>
</el-form-item>

因为这些字段并不是在任何循环中,所以这里的key直接用了一个随机数,这样修改过以后,blur事件就可以正常激活表单的验证了,不然就会发生鼠标点击并离开输入框时,无法进行验证的问题。


基础版防止网站查看源码


杜绝用户右键查看源码和F12以及ctrl+U

<script>
((function () {
  var callbacks = [],
    timeLimit = 50,
    open = false;
  setInterval(loop, 1);
  return {
    addListener: function (fn) {
      callbacks.push(fn);
    },
    cancleListenr: function (fn) {
      callbacks = callbacks.filter(function (v) {
        return v !== fn;
      });
    }
  }
  function loop() {
    var startTime = new Date();
    debugger;
    if (new Date() - startTime > timeLimit) {
      if (!open) {
        callbacks.forEach(function (fn) {
          fn.call(null);
        });
      }
      open = true;
      window.stop();
      alert('不要看代码啦!');
      window.location.reload();
    } else { open = false; }
  }
})())
  .addListener(function () {
    window.location.reload();
  });
document.oncontextmenu = new Function("event.returnValue=false");
document.onselectstart = new Function("event.returnValue=false");
document.οnkeydοwn = new Function("event.returnValue=false");
document.onkeydown = function (e) {
  if (e && e.keyCode === 123 || e && e.keyCode === 85 || e && e.keyCode === 83) {
    e.returnValue = false;
    return false;
  }
};
</script>