js:正则表达式

news2025/1/14 22:11:40

目录

正则表达式的语法

定义

检测

检索

元字符

边界符

量词

字符类

表单判断案例

修饰符

过滤敏感词


正则表达式是一种用于匹配和操作文本的强大工具,它是由一系列字符和特殊字符组成的模式,用于描述要匹配的文本字符组合模式

正则表达式是一种通用的模式,在js里一般用作验证表单:

用户名表单只能输入英文字母、数字或者下划线, 昵称输入框中可以输入中文(匹配

 过滤掉页面内容中的一些敏感词(替换),或从字符串中获取我们想要的特定部分(提取)等 。

正则表达式的语法

定义

定义正则表达式的语法,//内部是正则表达式的字面量

const reg=/兔子/

检测

使用test()方法:查看正则表达式与指定的字符串是否匹配

const str='我有三只小兔子'
//定义正则表达式
const reg=/兔子/
//是否匹配
console.log(reg.test(str));

匹配上了返回true,没匹配上返回false

reg是正则表达式的对象,test()是reg对象的方法,而定义的正则表达式就相当于一套规则

在实际使用中我们要先有一套规则,再进行检验

检索

除了test()还有一个方法

exec()方法:在一个指定字符串中执行一个搜索匹配

 const str='我有三只小兔子,分别是阿米娅兔兔,特雷西娅兔兔,德克萨斯兔兔'
        //定义正则表达式
        const reg=/兔兔/
        //是否匹配
        console.log(reg.exec(str));
如果匹配成功,exec() 方法返回一个数组,否则返回null

其中的index表示数组的下标14的位置上匹配成功

返回值不同是test()和exec()最大的区别

元字符

普通的字符只能描述他们本身,而元字符是一些具有特殊意义的字符,可以匹配一类字符,例如普通字符里想表示26个英文字母,需要abcdefg......一个一个写出来,但是元字符可以用[a-z]来表示这些字符

极大提高了灵活性和强大的匹配功能。

参考文档:MDN:https://developer.mozilla.org/zhCN/docs/Web/JavaScript/Guide/Regular_Expressions

正则表达式的测试工具: http://tool.oschina.net/regex

元字符太多了,所以我们对它做出分类,分别是边界符、量词、字符类

边界符

表示字符的位置,必须以某某字符开头、结尾等格式要求

第一个true:str里含有gigity

第二个和第三个的true是因为str以gigity开头/结尾

如果想要精确匹配:

//以某一字符开头,以某一字符结尾
console.log(/^gigity$/.test(str))

答案为什么是false?

当我们确定字符串的^和$(也就是开头和结尾),你们这个开头和结尾必须是同一个字符

也就是说只有这种情况才为true:

//和正则表达式里面的字符一模一样才是true
console.log(/^gigity$/.test('gigity'))/'/true

欸,那你就要问了(谁问你了)怎么表示多个重复字符的正则表达式字面量呢?所以我们要学:

量词

表示字符的重复次数,设定某个模式出现的次数

*:

const str = 'ygigitygigitygigitygigity'
         console.log(/^gigity*$/.test(str));//false
            console.log(/y*$/.test(str));//true

为什么第一个是false?第二个是true?

首先,在字符后面加【*】则这个字符只作用于该字符正前方的字符也就是【y】,那么这句正则表达式的意思就变成了【匹配的是以 "gigity" 开头,后面可以跟 0 个或多个 y 的字符串】,而该字符不满足这个规则,所以false

所以根据这个规则,我们写成第二种形式的意思是【含0个或多个y并且以y结尾的字符串】,str满足条件,所以true

如果你想匹配多个 "gigity" 的重复,可以使用 /^(gigity)+$/

const str = 'gigitygigitygigitygigity';
console.log(/^(gigity)+$/.test(str)); // true

当然如果我们写成这样:

console.log(/^y*$/.test(str));

就false了,因为这样的写法要求【字符串里只能有0或0个以上的y】

+:

改为+也很好理解,至少有一个【y】

 const str = 'ygigitygigitygigitygigity'
         console.log(/^gigity+$/.test(str));//false
            console.log(/y+$/.test(str));//true

?:

只有出现0和1次为true,其余都为false

const str = 'ygigitygigitygigitygigity'
         console.log(/^gigity?$/.test(str));//false
            console.log(/y?$/.test(str));//true

当然,以上三种量词也可以辨别空白:

  console.log(/^y*$/.test(''));//true
        console.log(/^y+$/.test(''));//false
        console.log(/^y?$/.test(''));//true

还可以设置固定字符出现的次数:只有只出现四个【y】时为true

console.log(/^y{3}$/.test(''));//false
console.log(/^y{3}$/.test('y'));//false
console.log(/^y{3}$/.test('yy'));//false
console.log(/^y{3}$/.test('yyy'));//true

可以用作判别手机号、验证码、身份证号码输入的位数是否正确

大于等于3即为true:

console.log(/^y{3,}$/.test('yy'));//false
console.log(/^y{3,}$/.test('yyy'));//true
console.log(/^y{3,}$/.test('yyyy'));//true
console.log(/^y{3,}$/.test('yyyyy'));//true

大于等于三,小于等于4即为true(注意{n,m}【,】左右两边没有空格):

console.log(/^y{3,4}$/.test('yy'));//false
console.log(/^y{3,4}$/.test('yyy'));//true
console.log(/^y{3,4}$/.test('yyyy'));//true
console.log(/^y{3,4}$/.test('yyyyy'));//false

字符类

类似于[a-z]等表示一类字符的元字符,\d表示0~9(其实我在学makefile的时候就没觉得正则表达式方便到哪去)

[]匹配字符集合,后面的字符串只要包含abc中的任意一个字符,都返回true:

当判定为【字符串里含a/b/c里的一个以上】的时候会判定为false,但是用上量词,就会变为true:

使用连字符表示一个范围:

Ø [a-z] 表示 a 到 z 26个英文字母都可以

Ø [a-zA-Z] 表示大小写都可以

Ø [0-9] 表示 0~9 的数字都可以

比如:

1、在[]内加^符表示取反,和[]内的字符取反,[^abc]表示【abc之外的所有其他字符】

2、【.】匹配除了换行符的任何单个字符

3、预定义类: 某些常见模式的简写方式。

表单判断案例

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        span {
            display: inline-block;
            width: 250px;
            height: 30px;
            vertical-align: middle;
            line-height: 30px;
            padding-left: 15px;
        }

        .error {
            color: red;
            /* background: url(./images/error1.png) no-repeat left center; */
        }

        .right {
            color: green;
            /* background: url(./images/right.png) no-repeat left center; */
        }
    </style>
</head>

<body>
    <input type="text">
    <span></span>
    <script>
        const reg = /^[a-zA-Z0-9-_]{6,16}$/
        const input = document.querySelector('input')
        const span = document.querySelector('span')
        input.addEventListener('blur', function () {
            if (reg.test(this.value)) {
                span.innerHTML = '输入正确'
                span.classList.remove('error')
                span.classList.add('right')
            } else {
                span.innerHTML = '请输入6-16位的英文、数字或下划线'
                // span.classList.remove('right')
                // span.classList.add('error')也可以用className来修改类名
                span.className='error'
            }
        })
    </script>
</body>

</html>

修饰符

修饰符约束正则执行的某些细节行为,如是否区分大小写、是否支持多行匹配等

语法:

i 是单词 ignore 的缩写,正则匹配时字母不区分大小写

g 是单词 global 的缩写,匹配所有满足正则表达式的结果,一般用于全局替换

替换:replace 替换

和g一起作用,或是【|】竖线:

过滤敏感词

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <textarea name="" id="" cols="30" rows="10"></textarea>
    <button>
        发布
    </button>
    <div></div>
    <script>
        const tx = document.querySelector('textarea')
        const btn = document.querySelector('button')
        const div = document.querySelector('div')
        btn.addEventListener('click', function () {
            // console.log(tx.value)
              div.innerHTML = tx.value.replace(/wcnm/g,'我上早八')
        })

    </script>
</body>

</html>

注册界面

利用之前学过的东西写一个注册页面

其中讲到了两个新的知识点:

change事件,是判断表单和之前的内容有没有区别的事件

classList.contains()可以确定该元素有没有包含某个类

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <title>小兔鲜儿 - 新鲜 惠民 快捷!</title>
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="renderer" content="webkit">
  <link rel="shortcut icon" href="./favicon.ico">
  <link rel="stylesheet" href="./css/common.css">
  <link rel="stylesheet" href="./css/register.css">
  <link rel="stylesheet" href="https://at.alicdn.com/t/font_2143783_iq6z4ey5vu.css">
</head>

<body>
  <!-- 项部导航 -->
  <div class="xtx_topnav">
    <div class="wrapper">
      <!-- 顶部导航 -->
      <ul class="xtx_navs">
        <li>
          <a href="./login.html">请先登录</a>
        </li>
        <li>
          <a href="./register.html">免费注册</a>
        </li>
        <li>
          <a href="./center-order.html">我的订单</a>
        </li>
        <li>
          <a href="./center.html">会员中心</a>
        </li>
        <li>
          <a href="javascript:;">帮助中心</a>
        </li>
        <li>
          <a href="javascript:;">在线客服</a>
        </li>
        <li>
          <a href="javascript:;">
            <i class="mobile sprites"></i>
            手机版
          </a>
        </li>
      </ul>
    </div>
  </div>
  <!-- 头部 -->
  <div class="xtx_header">
    <div class="wrapper">
      <!-- 网站Logo -->
      <h1 class="xtx_logo"><a href="/">小兔鲜儿</a></h1>
      <!-- 主导航 -->
      <div class="xtx_navs">
        <ul class="clearfix">
          <li>
            <a href="./index.html">首页</a>
          </li>
          <li>
            <a href="./category01.html">生鲜</a>
          </li>
          <li>
            <a href="./category01.html">美食</a>
          </li>
          <li>
            <a href="./category01.html">餐厨</a>
          </li>
          <li>
            <a href="./category01.html">电器</a>
          </li>
          <li>
            <a href="./category01.html">居家</a>
          </li>
          <li>
            <a href="./category01.html">洗护</a>
          </li>
          <li>
            <a href="./category01.html">孕婴</a>
          </li>
          <li>
            <a href="./category01.html">服装</a>
          </li>
        </ul>
      </div>
      <!-- 站内搜索 -->
      <div class="xtx_search clearfix">
        <!-- 购物车 -->
        <a href="./cart-none.html" class="xtx_search_cart sprites">
          <i>2</i>
        </a>
        <!-- 搜索框 -->
        <div class="xtx_search_wrapper">
          <input type="text" placeholder="搜一搜" onclick="location.href='./search.html'">
        </div>
      </div>
    </div>
  </div>
  <div class="xtx-wrapper">
    <div class="container">
      <!-- 卡片 -->
      <div class="xtx-card">
        <h3>新用户注册</h3>
        <form class="xtx-form">
          <div data-prop="username" class="xtx-form-item">
            <span class="iconfont icon-zhanghao"></span>
            <input name="username" type="text" placeholder="设置用户名称">
            <span class="msg"></span>
          </div>
          <div data-prop="phone" class="xtx-form-item">
            <span class="iconfont icon-shouji"></span>
            <input name="phone" type="text" placeholder="输入手机号码  ">
            <span class="msg"></span>
          </div>
          <div data-prop="code" class="xtx-form-item">
            <span class="iconfont icon-zhibiaozhushibiaozhu"></span>
            <input name="code" type="text" placeholder="短信验证码">
            <span class="msg"></span>
            <a class="code" href="javascript:;">发送验证码</a>
          </div>
          <div data-prop="password" class="xtx-form-item">
            <span class="iconfont icon-suo"></span>
            <input name="password" type="password" placeholder="设置6至20位字母、数字和符号组合">
            <span class="msg"></span>
          </div>
          <div data-prop="confirm" class="xtx-form-item">
            <span class="iconfont icon-suo"></span>
            <input name="confirm" type="password" placeholder="请再次输入上面密码">
            <span class="msg"></span>
          </div>
          <div class="xtx-form-item pl50">
            <i class="iconfont icon-queren"></i>
            已阅读并同意<i>《用户服务协议》</i>
          </div>
          <div class="xtx-form-item">
            <button class="submit">下一步</button>
            <!-- <a class="submit" href="javascript:;">下一步</a> -->
          </div>
        </form>
      </div>
    </div>
  </div>
  <!-- 公共底部 -->
  <div class="xtx_footer clearfix">
    <div class="wrapper">
      <!-- 联系我们 -->
      <div class="contact clearfix">
        <dl>
          <dt>客户服务</dt>
          <dd class="chat">在线客服</dd>
          <dd class="feedback">问题反馈</dd>
        </dl>
        <dl>
          <dt>关注我们</dt>
          <dd class="weixin">公众号</dd>
          <dd class="weibo">微博</dd>
        </dl>
        <dl>
          <dt>下载APP</dt>
          <dd class="qrcode">
            <img src="./uploads/qrcode.jpg">
          </dd>
          <dd class="download">
            <span>扫描二维码</span>
            <span>立马下载APP</span>
            <a href="javascript:;">下载页面</a>
          </dd>
        </dl>
        <dl>
          <dt>服务热线</dt>
          <dd class="hotline">
            400-0000-000
            <small>周一至周日 8:00-18:00</small>
          </dd>
        </dl>
      </div>
    </div>
    <!-- 其它 -->
    <div class="extra">
      <div class="wrapper">
        <!-- 口号 -->
        <div class="slogan">
          <a href="javascript:;" class="price">价格亲民</a>
          <a href="javascript:;" class="express">物流快捷</a>
          <a href="javascript:;" class="quality">品质新鲜</a>
        </div>
        <!-- 版权信息 -->
        <div class="copyright">
          <p>
            <a href="javascript:;">关于我们</a>
            <a href="javascript:;">帮助中心</a>
            <a href="javascript:;">售后服务</a>
            <a href="javascript:;">配送与验收</a>
            <a href="javascript:;">商务合作</a>
            <a href="javascript:;">搜索推荐</a>
            <a href="javascript:;">友情链接</a>
          </p>
          <p>CopyRight &copy; 小兔鲜儿</p>
        </div>
      </div>
    </div>
  </div>
  <script>
    //验证码模块
    const code = document.querySelector('.code')
    let flag = true
    let timerId = code.addEventListener('click', function () {
      if (flag) {
        flag = false
        let i = 5
        code.innerHTML = `0${i}秒后重新获取`
        setInterval(function () {
          i--
          code.innerHTML = `0${i}秒后重新获取`
          if (i === 0) {
            clearInterval(timerId)
            flag = true
            code.innerHTML = `重新获取`
          }
        }, 1000)
      }
    })
    //用户名验证
    const username = document.querySelector('[name=username]')
    username.addEventListener('change', verifyName)
    function verifyName() {
      //使用正则表达式验证
      const reg = /^[a-zA-Z0-9-_]{6,10}$/
      //使用兄弟节点操纵span,因为dom树里有很多span
      const span = username.nextElementSibling
      //如果不通过
      if (!reg.test(username.value)) {
        //console.log('不通过');
        span.innerText = '输入不合法,请输入6~10位'
        return false
      }
      //如果通过
      span.innerText = ''
      return true
    }
    //手机号验证
    const phone = document.querySelector('[name=phone]')
    phone.addEventListener('change', verifyPhone)
    function verifyPhone() {
      //使用正则表达式验证
      const reg = /^1(3\d|4[5-9]|5[0-35-9]|6[567]|7[0-8]|8\d|9[0-35-9])\d{8}$/
      //使用兄弟节点操纵span,因为dom树里有很多span
      const span = phone.nextElementSibling
      //如果不通过
      if (!reg.test(phone.value)) {
        //console.log('不通过');
        span.innerText = '输入不合法,请输入正确的11位手机号'
        return false
      }
      //如果通过
      span.innerText = ''
      return true
    }
    //验证码验证
    const codeInput = document.querySelector('[name=code]')
    codeInput.addEventListener('change', verifyCodeInput)
    function verifyCodeInput() {
      //使用正则表达式验证
      const reg = /^\d{6}$/
      //使用兄弟节点操纵span,因为dom树里有很多span
      const span = codeInput.nextElementSibling
      //如果不通过
      if (!reg.test(codeInput.value)) {
        //console.log('不通过');
        span.innerText = '输入不合法,请输入6位数字'
        return false
      }
      //如果通过
      span.innerText = ''
      return true
    }
    //密码验证
    const password = document.querySelector('[name=password]')
    password.addEventListener('change', verifyPassword)
    function verifyPassword() {
      //使用正则表达式验证
      const reg = /^[a-zA-Z0-9-_]{6,20}$/
      //使用兄弟节点操纵span,因为dom树里有很多span
      const span = password.nextElementSibling
      //如果不通过
      if (!reg.test(password.value)) {
        //console.log('不通过');
        span.innerText = '输入不合法,请输入6~20位数字、字母和符号'
        return false
      }
      //如果通过
      span.innerText = ''
      return true
    }
    //再次输入密码
    const confirm = document.querySelector('[name=confirm]')
    confirm.addEventListener('change', verifyConfirm)
    function verifyConfirm() {
      //使用兄弟节点操纵span,因为dom树里有很多span
      const span = confirm.nextElementSibling
      //如果不通过
      if (confirm.value !== password.value) {
        //console.log('两次输入密码不一致');
        span.innerText = '两次输入密码不一致'
        return false
      }
      //如果通过
      span.innerText = ''
      return true
    }
    //用户协议勾选状态切换
    const queren = document.querySelector('.icon-queren')
    queren.addEventListener('click', function () {
      //切换类,原有的删掉,没有的添加
      this.classList.toggle('icon-queren2')
    })
    //表单提交
    //没有勾选同意协议,提示需要勾选:classList.contains()查看有没有包含某个类,如果有则返回true,没有返回false
    //验证模块中有一个返回false则阻止提交
    const form = document.querySelector('form')
    form.addEventListener('submit', function () {
      if (!queren.classList.contains('icon-queren2')) {
        alert('请勾选同意协议')
        //阻止默认行为才能真正阻止提交
        e.preventDefault()
      }
      //判断先前的验证模块,返回false就代表没有通过验证
      if (!verifyName()) e.preventDefault()
      if (!verifyPhone) e.preventDefault()
      if (!verifyPassword) e.preventDefault()
      if (!verifyCodeInput) e.preventDefault()
      if (!verifyConfirm) e.preventDefault()
    })

  </script>
</body>

</html>

登录界面:

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <title>小兔鲜儿 - 新鲜 惠民 快捷!</title>
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="renderer" content="webkit">
  <link rel="shortcut icon" href="../favicon.ico">
  <link rel="stylesheet" href="./css/common.css">
  <link rel="stylesheet" href="./css/login.css">
  <link rel="stylesheet" href="https://at.alicdn.com/t/font_2143783_iq6z4ey5vu.css">
</head>

<body>
  <!-- 登录头部 -->
  <div class="xtx-login-header">
    <h1 class="logo"></h1>
    <a class="home" href="./index.html">进入网站首页</a>
  </div>
  <!-- 登录内容 -->
  <div class="xtx-login-main">
    <div class="wrapper">
      <form action="" autocomplete="off">
        <div class="box">
          <div class="tab-nav">
            <a href="javascript:;" class="active" data-id="0">账户登录</a>
            <a href="javascript:;" data-id="1">二维码登录</a>
          </div>
          <div class="tab-pane">
            <div class="link">
              <a href="javascript:;">手机验证码登录</a>
            </div>
            <div class="input">
              <span class="iconfont icon-zhanghao"></span>
              <input required type="text" placeholder="请输入用户名称/手机号码" name="username">
            </div>
            <div class="input">
              <span class="iconfont icon-suo"></span>
              <input required type="password" placeholder="请输入密码" name="password">
            </div>
            <div class="agree">
              <label for="my-checkbox">
                <input type="checkbox" value="1" id="my-checkbox" class="remember" name="agree">
                <span class="iconfont icon-xuanze"></span>
              </label>
              我已同意 <a href="javascript:;">《服务条款》</a href="javascript:;"> 和 <a>《服务条款》</a>
            </div>
            <div class="button clearfix">
              <button type="submit" class="dl">登 录</button>
              <!-- <a class="dl" href="./center.html">登 录</a> -->
              <a class="fl" href="./forget.html">忘记密码?</a>
              <a class="fr" href="./register.html">免费注册</a>
            </div>
          </div>
          <div class="tab-pane" style="display: none;">
            <img class="code" src="./images/code.png" alt="">
          </div>
        </div>
      </form>
    </div>
  </div>
  <!-- 登录底部 -->
  <div class="xtx-login-footer">
    <!-- 版权信息 -->
    <div class="copyright">
      <p>
        <a href="javascript:;">关于我们</a>
        <a href="javascript:;">帮助中心</a>
        <a href="javascript:;">售后服务</a>
        <a href="javascript:;">配送与验收</a>
        <a href="javascript:;">商务合作</a>
        <a href="javascript:;">搜索推荐</a>
        <a href="javascript:;">友情链接</a>
      </p>
      <p>CopyRight &copy; 小兔鲜儿</p>
    </div>
  </div>
  <script>
    //判断是否通过事件委托来自注册事件,关系太复杂的盒子(互相套来套去不建议使用事件委托)
    //tab栏切换,使用事件委托
    const tab_nav = document.querySelector('.tab-nav')
    const pane = document.querySelectorAll('.tab-pane')
    tab_nav.addEventListener('click', function (e) {
      if (e.target.tagName === 'A') {
        //取消上一个active,位当前元素添加active
        tab_nav.querySelector('.active').classList.remove('active')
        e.target.classList.add('active')
        //通过for()循环将两个盒子都隐藏
        for (let i = 0; i < pane.length; i++) {
          pane[i].style.display = 'none'
        }
        //让对应需要的pane显示
        pane[e.target.dataset.id].style.display = 'block'
      }
    })
    //点击提交模块
    const form = document.querySelector('form')
    const agree = document.querySelector('[name=agree]')
    form.addEventListener('submit', function (e) {
      e.preventDefault()
      //判断是否勾选同意协议
      if (!agree.checked) {
        return alert('请勾选同意协议')
      }
      //保存用户名到本地
      const username = document.querySelector('[name=username]')
      localStorage.setItem('xtx-uname', username.value)
      //跳转到主页
      location.href = './index.html'
    })
   
  </script>
</body>

</html>

从登陆页面跳转到主页的模块:js

<script>
    //从登录页面跳转过来   
    //获取第一个li
    const li1 = document.querySelector('.xtx_navs li:first-child')
    const li2 = li1.nextElementSibling
    function render() {
      const uname = localStorage.getItem('xtx-uname')
      //console.log(uname)
      if (uname) {
        li1.innerHTM = `<a href="javascript:;"><i class="iconfont icon-user">${uname}</i></a>`
        li2.innerHTML = `<a href="javascript:;">退出登录</a>`
      } else {
        li1.innerHTML = `<a href="./login.html">请先登录</a>`
        li2.innerHTML = `<a href="./register.hmtl">免费注册</a>`
      }
    }
    render()
    //退出登录的模块
    li2.addEventListener('click', function () {
      localStorage.removeItem('xtx-uname')
      render()
    })
  </script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2276670.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

PHP数据过滤函数详解:filter_var、filter_input、filter_has_var等函数的数据过滤技巧

PHP数据过滤函数详解&#xff1a;filter_var、filter_input、filter_has_var等函数的数据过滤技巧&#xff0c;需要具体代码示例 在 Web 开发中&#xff0c;数据过滤是非常重要的一环。过滤用户输入的数据可以保护我们的应用程序免受潜在的安全威胁。PHP 提供了一系列强大的数…

QT跨平台应用程序开发框架(1)—— 环境搭建

目录 一&#xff0c;关于QT 二&#xff0c;关于应用程序框架 三&#xff0c;环境搭建 3.1 预备 3.2 下载Qt SDK 3.3 安装Qt SDK 3.4 配置环境变量 3.5 认识一些重要工具 四&#xff0c;Qt Creator 的基本使用 4.1 创建项目 4.2 代码解释 一&#xff0c;关于QT 互联网…

【MySQL】基础架构分析

考察频率难度40%⭐⭐⭐⭐ 这道题在面试时的出现频率其实并不高&#xff0c;最起码对于笔者来说是没有遇到过。那为什么还是选择把这个问题作为 MySQL 八股文系列的第一个呢&#xff1f;其实原因也挺简单的&#xff0c;还是老规矩&#xff0c;先通过一个问题把整个知识框架来一…

【华为云开发者学堂】基于华为云 CodeArts CCE 开发微服务电商平台

实验目的 通过完成本实验&#xff0c;在 CodeArts 平台完成基于微服务的应用开发&#xff0c;构建和部署。 ● 理解微服务应用架构和微服务模块组件 ● 掌握 CCE 平台创建基于公共镜像的应用的操作 ● 掌握 CodeArts 平台编译构建微服务应用的操作 ● 掌握 CodeArts 平台部署微…

Elasticsearch ES|QL 地理空间索引加入纽约犯罪地图

可以根据地理空间数据连接两个索引。在本教程中&#xff0c;我将向你展示如何通过混合邻里多边形和 GPS 犯罪事件坐标来创建纽约市的犯罪地图。 安装 如果你还没有安装好自己的 Elasticsearch 及 Kibana 的话&#xff0c;请参考如下的链接来进行安装。 如何在 Linux&#xff0…

P10打卡——pytorch实现车牌识别

&#x1f368; 本文为&#x1f517;365天深度学习训练营中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 1.检查GPU from torchvision.transforms import transforms from torch.utils.data import DataLoader from torchvision import datasets import torchvisio…

GitCode G-Star 光引计划终审前十名获奖项目公示

在技术的浩瀚星空中&#xff0c;GitCode 平台上的 G-Star 项目熠熠生辉。如今&#xff0c;“光引计划” 已圆满落幕&#xff0c;众多 G-Star 项目作者&#xff0c;一同分享项目在 GitCode 平台托管的宝贵体验&#xff0c;并深入挖掘平台的多样玩法。 众多投稿纷至沓来&#xf…

【pycharm】远程部署失败,查看日志

pycharm 远程部署失败,查看日志 远程一直失败,gateway超时会还知道拉取一份日志: 在./root 下 发现了崩溃日志,启动崩溃了,导致backend一直无法启动。win11就是一直在connect到ubuntu的后端pycharm。。gateway 拉取的日志 我上传的linux版本的pycharm暂时存在dist目录下,…

浅谈云计算02 | 云计算模式的演进

云计算计算模式的演进 一、云计算计算模式的起源追溯1.2 个人计算机与桌面计算 二、云计算计算模式的发展阶段2.1 效用计算的出现2.2 客户机/服务器模式2.3 集群计算2.4 服务计算2.5 分布式计算2.6 网格计算 三、云计算计算模式的成熟与多元化3.1 主流云计算服务模式的确立3.1.…

Vue 学习之旅:从基础到实践(vue快速上手+插值表达式+指令上)

Vue 学习之旅&#xff1a;从基础到实践 文章目录 Vue 学习之旅&#xff1a;从基础到实践一、Vue 简介二、创建 Vue 实例与插值表达式&#xff08;一&#xff09;创建 Vue 实例步骤&#xff08;二&#xff09;插值表达式 三、Vue 核心特性 - 响应式四、Vue 指令&#xff08;一&a…

PMP–一、二、三模、冲刺–分类–7.成本管理

文章目录 技巧一模7.成本管理--4.控制成本--数据分析--挣值分析--进度绩效指数&#xff08;SPI&#xff09;是测量进度效率的一种指标&#xff0c;表示为挣值与计划价值之比&#xff0c;反映了项目团队完成工作的效率。 当 SPI小于 1.0 时&#xff0c;说明已完成的工作量未达到…

字符串 (算法十一)

简介 没有固定题型&#xff0c;内容很杂&#xff0c;可以学习下string接口与相关操作 1.最长公共前缀 link&#xff1a; 解法一&#xff1a;两两比较 code class Solution { public:string longestCommonPrefix(vector<string>& strs) {// 两两比较string ans …

摄像头模块在狩猎相机中的应用

摄像头模块是狩猎相机的核心组件&#xff0c;在狩猎相机中发挥着关键作用&#xff0c;以下是其主要应用&#xff1a; 图像与视频拍摄 高清成像&#xff1a;高像素的摄像头模块可确保狩猎相机拍摄出清晰的图像和视频&#xff0c;能够捕捉到动物的毛发纹理、行为细节及周围环境的…

给DevOps加点料:融入安全性的DevSecOps

从前&#xff0c;安全防护只是特定团队的责任&#xff0c;在开发的最后阶段才会介入。当开发周期长达数月、甚至数年时&#xff0c;这样做没什么问题&#xff1b;但是现在&#xff0c;这种做法现在已经行不通了。 采用 DevOps 可以有效推进快速频繁的开发周期&#xff08;有时…

沸点 | 聚焦嬴图Cloud V2.1:具备水平可扩展性+深度计算的云原生嬴图动力站!

近日&#xff0c;嬴图正式推出嬴图Cloud V2.1&#xff0c;此次发布专注于提供无与伦比的用户体验&#xff0c;包括具有水平可扩展性的嬴图Powerhouse的一键部署、具有灵活定制功能的管理控制台、VPC / 专用链接等&#xff0c;旨在满足用户不断变化需求的各项前沿功能&#xff0…

Mysql--架构篇--存储引擎InnoDB(内存结构,磁盘结构,存储结构,日志管理,锁机制,事务并发控制等)

MySQL是一个多存储引擎的数据库管理系统&#xff0c;支持多种不同的存储引擎。每种存储引擎都有其独特的特性、优势和适用场景。选择合适的存储引擎对于优化数据库性能、确保数据完整性和满足业务需求至关重要。 注&#xff1a;在同一个Mysql的数据库中&#xff0c;对于不同的表…

springboot高校电子图书馆的大数据平台规划与设计

Spring Boot高校电子图书馆的大数据平台规划与设计是一个综合性的项目&#xff0c;旨在利用现代信息技术提升高校电子图书馆的服务质量和管理效率。以下是对该项目的详细介绍&#xff1a; 一、背景与需求 随着高校教育信息化的不断推进&#xff0c;电子图书馆的资源和用户数量…

lwip单网卡多ip的实现

1、今天要实现lwip的多个ip配置&#xff0c;本来以为需要自己修改很多核心代码 2、查阅资料才发现&#xff0c;lwip已经把接口留出来了 /** Define this to 1 and define LWIP_ARP_FILTER_NETIF_FN(pbuf, netif, type) * to a filter function that returns the correct neti…

《零基础Go语言算法实战》【题目 2-22】Go 调度器优先调度问题

《零基础Go语言算法实战》 【题目 2-22】Go 调度器优先调度问题 下面代码的输出是什么&#xff1f;请说明原因。 package main import ( "fmt" "runtime" "sync" ) func main() { runtime.GOMAXPROCS(1) wg : sync.WaitGroup{} wg.Add(10)…

浏览器输入http形式网址后自动跳转https解决方法

一、问题描述 使用浏览器 网上冲浪 时会遇到一个情况&#xff1a; 在浏览器中输入“http域名”后会自动变成“https 域名”的形式&#xff0c;此时“https 域名”的网站可能已停止对外提供服务了&#xff0c;这时会出现如下不友好的网页提示&#xff1a; 二、处理方法&#x…