别具一格,原创唯美浪漫情人节表白专辑,(复制就可用)(html5,css3,svg)表白爱心代码(1)

news2024/9/21 23:34:48

别具一格,原创唯美浪漫情人节表白专辑,

(复制就可用)(html5,css3,svg)表白爱心代码(1)

 一、 前言

  回眸之间,丰盈了岁月,涟漪了思绪,轻轻落笔,不写伤痕,不写仇怨,只写岁月经历领悟后的感恩与体会。

  说来有点尴尬,我一个奶奶级别的,却从来没有交过男朋友,也从来没有做过任何不应该做的事情。

  每个人的天分不一样,经历也不一样。我一直很安静很乖的等着我生命中的唯一来找我,由他带我走向生命中的另一段旅程。因世事变迁,很遗憾我确认他不会出现了。但我依然会尊重自己,不论遭遇什么,多少岁了,我依然会是他心中的那个好女孩。

  所以,情人节或平日里看到别人双双对对,我并不会感到任何……因为我的心一直是满的。

  有些人,无论身份是什么,在岁月的流转中悄悄从你生命中退出,但在与不在,都会在你岁月中留下了华美的荏苒。不需太多,仅仅是一句话,一点面具后的恻隐,那份隐而不说的不舍,一句发自真切的关心话,在你落难时没有随大流狠踩一脚的义气,……岁月静好,念起便是温暖。点点滴滴,如缕缕阳光,温暖迷雾中的前程。

  经历过的风景,有黑有白,装点着生活的诗意,叠加着光阴的故事,如果带着一份感激的心态去领悟,便是携了一款时光宝盒,将生命的本真化作阳光雨露……心情低落时,拿出来重新感受一下,可以驱散心中的阴霾。

  一句温暖的话,我可以记一辈子。因为我知道生活不易,还能给与别人温暖并不是一件容易的事。正如我,现在一直在经历着一些我不愿意经历的事情,但我还是在努力做着一些我能做到的事情,当中的滋味只有自己心里清楚。

  最近,96岁星云法师因病辞世,他有句话:以金相交,金耗则忘;以利相交,利尽则散;以势相交,势去则倾;以权相交,权失则弃;以情相交,情逝人伤;唯心相交,静行致远

  这世间有很多无奈,有很多让人心寒的事,其实我和所有人一样,心中也有迷茫,受伤也曾想放弃,为什么他们可以忍心这样做?可生活总要继续,如果我们只记得别人给与的伤害,除了让自己心灰意冷之外,还会把本应属于你的阳光拒之门外。因为当你低着头忙着数伤痕时,会忘了抬头看看天空,白天,阳光很温暖;夜晚,会有月亮,就算是看不见月亮了,还会有星星,她们依然在那里闪烁,温暖着每一个心情低落的人。。。

  缘分向来可遇不可求,如果遇见了自己喜欢的,就不要苛求,而是多给彼此一些包容和欣赏,如此,这份情才能长长久久,余生,才能拥有真正的岁月静好。每个人的相处模式不一样,最重要是想清楚你要的是什么,寻找你想要的,找到了,就要好好珍惜,记住多体谅一下别人,不要以自己的标准去评价衡量别人。

  立场不同、所处环境不同的人,很难真正了解对方的感受,每个人都要学会习惯源于生命深处的孤独,没有谁能够永远陪着谁,孤单的滋味谁都要面对。因此对别人的失意、挫折、伤痛,不要幸灾乐祸,而应以宽容之心待之,大家都有各自的不容易。不要随便去伤害任何人,因为你的一言一行,有可能就成为压死骆驼的最后一根稻草,所有人都是平等的,不论财富多少。

  世界变化很大,我一直在学着把这世上最令人恐惧的东西,视为生命的前提去接受,相信自己的为人,坚持做最初的自己,只要不是自己主动愿意去。。。那么无论发生什么,还会是原来的那个自己,纯洁而美好。菩提本无树,明镜亦非台。本来无一物,何处惹尘埃。在这一生中,学会与自己相处,与世界博弈,好奇而温暖地活着,守护着身边能够守护到的人。。。看得懂的,互勉。

  最好的余生,是有彼此相爱之人陪伴你,在漫长的未来一起看看日出日落,静赏云卷云舒;一起读书学习对抗平庸;一起面对各种突如其来的意外;一起。。。。。。一起人间烟火,一起面对生老病死,患难与共不离不弃。愿你们早日遇见这样可以相信的人,共度余生。

  下面这几款是我2023年2月新做的页面,专为送给世间所有有情之人而准备,我放在我这个唯一博客上(csdn,博客名:逆境清醒),有缘看到的,只管拿去送给你自己喜欢的人,免费,是全部的完整源代码,拷贝复制后简单修改即可用(为防我无法控制的意外发生,下载后请自行查杀毒)。我一直觉得,情人节是属于彼此相爱之人的节日,能遇到真心对你好的人不容易,无论婚否,有什么想跟他(她)说的,趁这个机会向他(她)表达一下。好好珍惜彼此的缘分。

  “2023唯美浪漫情人节表白专辑” 页面是我设计制作的,主体js代码来源于网络,我按需做了修改。复制后简单修改名字和表白文字就可使用,希望在这个情人节能帮你们更好地向你所喜欢的人表达内心的感受,能遇到一个真心。

  请勿将此几款情人节表白页面用作任何商业用途,只赠给那些有情之人作表白用途。

2023年2.12

二、效果图预览

款式一

款式二

 款式三

 款式四

三、如何使用,常见问题说明


1、电脑桌面新建一个txt文本文档(鼠标右击然后点击新建文本文档)

2、在我的博客挑选一种你喜欢的情人节表白款式,然后点击该款式所相应的源代码右侧的复制按钮,复制所有代码

3、进入刚才在桌面建立的txt文档,点击【编辑】-->【粘贴】,把代码复制进记事本。

 4、点击【文件】-->【保存】

  5、点击【退出】关闭记事本。

  6、桌面上选中刚才的文本文件,右键点击,修改文件名为index. ,此时会有改名提示,点击【是】按钮。

  

 7、如果有.js文件,请按上面方法建立js文件夹,将js后缀的文件放于此文件夹中。如果有图片,请建立img文件夹,将图片保存到此文件夹中。

 8、双击index.html文件打开即可看到效果。

9、修改表白文字。右键点击html文件,选择打开方式为记事本即可。如果你有编译器的话,还可以导入这个文件,就可以看到并修改代码了。每款的修改方法我会在该款展示中做说明。

10、怎么发给自己喜欢的人看?如果你喜欢的这个代码只是单独的一个html文件,那么直接发html文件给她(他)即可,让她(他)用系统自带的浏览器打开。
如果这个代码除了html文件还有其他的文件夹,比如js文件,图片,音频等等,那就需要把整个文件夹压缩然后把压缩包发给她。这个压缩包解压后,打开html文件即可看到效果。
 

四、各款式完整源代码

款式一:心形图片跳动爱心款

 动态局部图:

适用:手里有所喜欢的人的大头像,可写表白文字,可长可短。

修改使用方法:

1、拷贝完整源代码。

保存成index.html文件。具体方法见本文“三、如何使用,常见问题说明”部分的介绍。

2、设置跳动爱心上显示的图片

将自己喜欢人的头像图片保存在\img目录下,文件名为t1.jpg

3、修改表白文字

用记事本打开index.html文件,找到:

 修改【有你在真好。。。。。(张爱玲)】这一段的文字,这是显示在头像旁边的心形环绕文字,注意文字字数不能超46个(包括标点符号),否则显示效果不佳。

 修改【即使忘记了他的声音。。。。。郭敬明】这一段的文字,

 修改【岁月悄悄的流转,。。。。。念起便是温暖。】这一段的文字,

 修改【经历过的风景,。。。。。体味生命本真。】这一段的文字,

 修改【一条路,。。。。。“种着”梦想。】这一段的文字,

 修改【表白文字】这一段的文字,

这是显示在表白框里的文字,

注意:【<p>&nbsp;&nbsp;&nbsp;&nbsp;】这几句不要动,可以显示段前缩进2个中文字的宽度。

 4、检验修改表白内容后的效果

双击运行index.html文件,或用浏览器打开index.html文件,即可显示表白效果。

5、打包发送

将你的文件打包成.zip\.rar等通用压缩格式(index.html和img目录一起),发给你喜欢的人,让她(他)解压压缩包后,运行index.html文件即可。

6、完整源代码

index.html文件完整源代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <meta charset="utf-8" />
    <link rel="apple-touch-icon" type="image/png" href="https://.png" />
    <link rel="shortcut icon" type="image/x-icon" href="https://.ico" />
    <link rel="mask-icon" type="image/x-icon" href="https://.svg" color="#111" />
    <meta name="逆境清醒2023情人节专辑" content="逆境清醒2023情人节专辑">
    <title>(相片)跳动爱心----设计by逆境清醒---</title>
    <link rel="stylesheet" href=".css">
    <style>
        body {
            font-family: consolas;
            color: white;
            background-repeat: no-repeat;
            background-attachment: fixed;
            background-image: -webkit-linear-gradient(#e66465, #9198e5);
            background-image: -moz-linear-gradient(#e66465, #9198e5);
            background-image: -ms-linear-gradient(#e66465, #9198e5);
            background-image: -o-linear-gradient(#e66465, #9198e5);
            background-image: linear-gradient(#e66465, #9198e5);
            top: 80px;
            bottom: 0;
            left: 0;
            right: 0;
            width: 100%;
            height: 100%;
            display: flex;
            justify-content: center;
            align-items: center;
            flex-direction: column;
        }

        .maindiv {
            transform: 50%,50%;
            display: flex;
            justify-content: center;
            margin: 80px,auto;
            display: flex;
        }

        svg {
            width: 110vmin;
            display: block;
            position: relative;
            margin: 80px,auto;
            z-index: 1;
            justify-content: center;
        }

        text {
            fill: white;
            font-family: consolas;
            font-size: 9px
        }

        .say {
            position: relative;
            z-index: 2;
            width: 110vmin;
            top: 580px;
            background-color: silver;
            padding: 20px;
            line-height: 40px;
            margin: 0;
            color: black;
            font-size: 18px;
            background: #c1d5eb;
            font-family: 'kaiti','microsoft yahei';
            text-shadow: 0px 1px 0px #f2f2f2;
            top: 0px;
            justify-content: center;
            border-style: double;
            border-radius: 20px;
            border: 5px solid #9198e5;
        }

        /*:*/
    </style>

</head>
<body>

    <div class="maindiv">


        <svg id="theSvg" viewBox="-120 -30 240 180" enable-background="new 0 0 174 148" xml:space="preserve">
        <defs>
        <filter id="f" filterUnits="userSpaceOnUse" x="-120" y="-30" width="120%" height="120%">
        <feGaussianBlur in="SourceAlpha" stdDeviation="5" result="blur"></feGaussianBlur>
        <feOffset in="blur" dx="3" dy="5" result="shadow"></feOffset>
        <feFlood flood-color="#4d0014" result="color"></feFlood>
        <feComposite in="color" in2="shadow" operator="in"></feComposite>
        <feComposite in2="SourceGraphic"></feComposite>
        </filter>
        <path id="shape" d="M0, 21.054  C0, 21.054 24.618, -15.165 60.750, 8.554 C93.249, 29.888 57.749, 96.888 0, 117.388 C-57.749, 96.888  -93.249, 29.888 -60.750, 8.554 C-24.618, -15.165  -0, 21.054 -0, 21.054z"></path>
        <path id="partialPath" d="M0, 21.054 C0, 21.054 24.618, -15.165 60.750, 8.554 C93.249, 29.888 57.749, 96.888 0, 117.388 C-57.749, 96.888  -93.249, 29.888 -60.750, 8.554 -24.618000000002304,-15.164999999998484  -3.147704319417244e-12,21.053999999995362  -3.0171089725444906e-25,21.054 "></path>
    </defs>

<defs>
        <clipPath id="clip">
        <path d="M0, 21.054 C0, 21.054 24.618, -15.165 60.750, 8.554 C93.249, 29.888 57.749, 96.888 0, 117.388 C-57.749, 96.888  -93.249, 29.888 -60.750, 8.554 -24.618000000002304,-15.164999999998484  -3.147704319417244e-12,21.053999999995362  -3.0171089725444906e-25,21.054 "></path>
    </clipPath>
        <linearGradient id="linear" x1="0.3" y1="0.3" x2=".7" y2=".7" spreadMethod="reflect">
        <stop offset="0" stop-color="#00F"></stop>
        <stop offset="1" stop-color="#FF0"></stop>
    </linearGradient>
</defs>
<!-- -->
        <text dy="-2" filter="url(#f)">
        <textPath xlink:href="#partialPath" startOffset="12" stroke="white" stroke-width=".5">有你在真好:我想让你知道,这个世界上总会有人在等你,无论何时何地,总有这样的人。--(张爱玲)</textPath>
    </text>
        <use id="useThePath" xlink:href="#partialPath" stroke="white" stroke-width="1.5" stroke-opacity=".5" fill="red" style="display: block; background-image: radial-gradient(circle,#f79e9e, #9b0202) "></use>
        <set attributeName="x" attributeType="XML" to="60" begin="8s" />
        <animateTransform attributeName="transform" type="scale" from="1" to="0.8" begin="8s" dur="1s" repeatCount="indefinite" xlink:href="#useThePath" />


        <image id="tuimage" xlink:href="./img/t1.jpg" x="-75" y="-8" width="148" preserveAspectRatio="none" style="clip-path: url(#clip)" opacity=".5">
        <animateTransform attributeName="transform" type="scale" from="1" to="0.8" begin="8s" dur="1s" repeatCount="indefinite" xlink:href="#tuimage" />
        </image>
</svg>


        <script language="javascript">
            let rid = null; 
            const SVG_NS = "http://www.w3.org/2000/svg";
            const pathlength = shape.getTotalLength();
            let t = 0; 
            let lengthAtT = pathlength * t;
            let d = shape.getAttribute("d");
            let n = d.match(/C/gi).length; 
            let pos = 0; 
            class subPath {
                constructor(d) {
                    this.d = d;
                    this.get_PointsRy();
                    this.previous = subpaths.length > 0 ? subpaths[subpaths.length - 1] : null;
                    this.measurePath();
                    this.get_M_Point(); 
                    this.lastCubicBezier;
                    this.get_lastCubicBezier();
                }

                get_PointsRy() {
                    this.pointsRy = [];
                    let temp = this.d.split(/[A-Z,a-z\s,]/).filter(v => v); // remove empty elements
                    temp.map(item => {
                        this.pointsRy.push(parseFloat(item));
                    }); 
                }

                measurePath() {
                    let path = document.createElementNS(SVG_NS, "path");
                    path.setAttributeNS(null, "d", this.d);
                    this.pathLength = path.getTotalLength();
                }

                get_M_Point() {
                    if (this.previous) {
                        let p = this.previous.pointsRy;
                        let l = p.length;
                        this.M_point = [p[l - 2], p[l - 1]];
                    } else {
                        let p = this.pointsRy;
                        this.M_point = [p[0], p[1]];
                    }
                }

                get_lastCubicBezier() {
                    let lastIndexOfC = this.d.lastIndexOf("C");
                    let temp = this.d
                        .substring(lastIndexOfC + 1)
                        .split(/[\s,]/)
                        .filter(v => v);
                    let _temp = [];
                    temp.map(item => {
                        _temp.push(parseFloat(item));
                    });
                    this.lastCubicBezier = [this.M_point];
                    for (let i = 0; i < _temp.length; i += 2) {
                        this.lastCubicBezier.push(_temp.slice(i, i + 2));
                    }
                }
            }

            let subpaths = [];
            for (let i = 0; i < n; i++) {
                let newpos = d.indexOf("C", pos + 1);
                if (i > 0) {
                    let sPath = new subPath(d.substring(0, newpos));
                    subpaths.push(sPath);
                }
                pos = newpos;
            }
            subpaths.push(new subPath(d));
            let index;
            for (index = 0; index < subpaths.length; index++) {
                if (subpaths[index].pathLength >= lengthAtT) {
                    break;
                }
            }

            function get_T(t, index) {
                let T;
                lengthAtT = pathlength * t;
                if (index > 0) {
                    T =
                        (lengthAtT - subpaths[index].previous.pathLength) /
                        (subpaths[index].pathLength - subpaths[index].previous.pathLength);
                } else {
                    T = lengthAtT / subpaths[index].pathLength;
                }
                return T;
            }

            let T = get_T(t, index);

            let newPoints = getBezierPoints(T, subpaths[index].lastCubicBezier);

            drawCBezier(newPoints, partialPath, index);

            function getBezierPoints(t, points) {
                let helperPoints = [];
                for (let i = 1; i < 4; i++) {
                    let p = lerp(points[i - 1], points[i], t);
                    helperPoints.push(p);
                }
                helperPoints.push(lerp(helperPoints[0], helperPoints[1], t));
                helperPoints.push(lerp(helperPoints[1], helperPoints[2], t));
                helperPoints.push(lerp(helperPoints[3], helperPoints[4], t));
                let firstBezier = [
                    points[0],
                    helperPoints[0],
                    helperPoints[3],
                    helperPoints[5]
                ];
                return firstBezier;
            }

            function lerp(A, B, t) {
                let ry = [
                    (B[0] - A[0]) * t + A[0], //x
                    (B[1] - A[1]) * t + A[1] //y
                ];
                return ry;
            }

            function drawCBezier(points, path, index) {
                let d;

                if (index > 0) {
                    d = subpaths[index].previous.d;
                } else {
                    d = `M${points[0][0]},${points[0][1]} C`;
                }

                for (let i = 1; i < 4; i++) {
                    d += ` ${points[i][0]},${points[i][1]} `;
                }
                partialPath.setAttributeNS(null, "d", d);
            }

            t = 0.025;
            function Typing() {
                rid = window.requestAnimationFrame(Typing);
                if (t >= 1) {
                    window.cancelAnimationFrame(rid);
                    rid = null;
                } else {
                    t += 0.0025;
                }

                lengthAtT = pathlength * t;
                for (index = 0; index < subpaths.length; index++) {
                    if (subpaths[index].pathLength >= lengthAtT) {
                        break;
                    }
                }
                T = get_T(t, index);
                newPoints = getBezierPoints(T, subpaths[index].lastCubicBezier);
                drawCBezier(newPoints, partialPath, index);
            }

            Typing();
            theSvg.addEventListener("click", () => {
                if (rid) {
                    window.cancelAnimationFrame(rid);
                    rid = null;
                } else {
                    if (t >= 1) {
                        t = 0.025;
                    }
                    rid = window.requestAnimationFrame(Typing);
                }
            });

            cb.addEventListener("input", () => {
                if (cb.checked) {
                    useThePath.style.display = "block";
                } else {
                    useThePath.style.display = "none";
                }
            });
            ; console.log('2023年,逆境清醒 ');

        </script>
    </div>
        <div class="say">
            <p>&nbsp;&nbsp;&nbsp;&nbsp;即使忘记了他的声音,忘记了他的微笑,忘记了他的脸,有些人总会被铭刻在他们的记忆中,但是当你想到他时,这种感觉永远不会改变。------郭敬明</p>
            <p>&nbsp;&nbsp;&nbsp;&nbsp;岁月悄悄的流转,有些人,在与不在都在岁月中留下了华美的荏苒。岁月静好,念起便是温暖。</p>
            <p>&nbsp;&nbsp;&nbsp;&nbsp;经历过的风景,装点着生活的诗意,叠加着的光阴故事,带着一份感激去记得。携一缕阳光,体味生命本真。</p>
            <p>&nbsp;&nbsp;&nbsp;&nbsp;一条路,人烟稀少,孤独难行。却不得不坚持前行。因为它的尽头,“种着”梦想。</p>
            <p>&nbsp;&nbsp;&nbsp;&nbsp;表白文字</p>
            <p>&nbsp;&nbsp;&nbsp;&nbsp;表白文字</p>
        </div>

</body>
</html>

 

原创唯美浪漫情人节表白专辑(1)
原创唯美浪漫情人节表白专辑(2)
原创唯美浪漫情人节表白专辑(3)
原创唯美浪漫情人节表白专辑(4)

  推荐阅读:

原创唯美浪漫情人节表白专辑,(复制就可用)(html5,css3,svg)更好的向你所喜欢的人表达内心的感受。

2023年春节祝福第二弹——送你一只守护兔,让它温暖每一个你【html5 css3】画会动的小兔子
25

2023春节祝福系列第一弹(放飞祈福孔明灯,祝福大家身体健康)(附完整源代码及资源免费下载)
24

HTML+CSS+svg绘制精美彩色闪灯圣诞树,HTML+CSS+Js实时新年时间倒数倒计时(附源代码)

23

​草莓熊python绘图(春节版,圣诞倒数雪花版)附源代码

22

【程序人生】卡塔尔世界杯元素python海龟绘图(附源代码),世界杯主题前端特效5个(附源码)

21

0a4256d5e96d4624bdca36433237080b.png

​​

python爱心源代码集锦
20

4d9032c9cdf54f5f9193e45e4532898c.png

​​

巴斯光年python turtle绘图__附源代码
19

074cd3c255224c5aa21ff18fdc25053c.png

​​​

Three.js实例详解___旋转的精灵女孩(附完整代码和资源)
18

daecd7067e7c45abb875fc7a1a469f23.png

​​​​

​草莓熊python turtle绘图(玫瑰花版)附源代码

17

fe88b78e78694570bf2d850ce83b1f69.png

​​​​

立体多层玫瑰绘图源码__玫瑰花python 绘图源码集锦

16

c5feeb25880d49c085b808bf4e041c86.png

​​​​

皮卡丘python turtle海龟绘图(电力球版)附源代码

15

38266b5036414624875447abd5311e4d.png

​​​​

【CSDN云IDE】个人使用体验和建议(含超详细操作教程)(python、webGL方向)

14

03ed644f9b1d411ba41c59e0a5bdcc61.png

​​​​

草莓熊python turtle绘图(风车版)附源代码

13

09e08f86f127431cbfdfe395aa2f8bc9.png

​​​​

用代码过中秋,python海龟月饼你要不要尝一口?

12

40e8b4631e2b486bab2a4ebb5bc9f410.png

​​​​

《 Python List 列表全实例详解系列》__系列总目录

11

938bc5a8bb454a41bfe0d4185da845dc.jpeg

​​​​

用代码写出浪漫__合集(python、matplotlib、Matlab、java绘制爱心、玫瑰花、前端特效玫瑰、爱心)

10

0f09e73712d149ff90f0048a096596c6.png

​​​​

Python函数方法实例详解全集(更新中...)

9

93d65dbd09604c4a8ed2c01df0eebc38.png

​​​​

matplotlib 自带绘图样式效果展示速查(28种,全)

8

aa17177aec9b4e5eb19b5d9675302de8.png

​​​​

手机屏幕坏了____怎么把里面的资料导出(18种方法)

7

1750390dd9da4b39938a23ab447c6fb6.jpeg

​​​​

2023年1月多家权威机构____编程语言排行榜__薪酬状况

6

dc8796ddccbf4aec98ac5d3e09001348.jpeg

​​​​

Python中Print()函数的用法___实例详解(全,例多)

5

1ab685d264ed4ae5b510dc7fbd0d1e55.jpeg

​​​​

色彩颜色对照表(300种颜色)(16进制、RGB、CMYK、HSV、中英文名)

4

80007dbf51944725bf9cf4cfc75c5a13.png

​​​​

Node.js (v19.1.0npm 8.19.3) vue.js安装配置教程(超详细)

3

c6374d75c29942f2aa577ce9c5c2e12b.png

​​​​

Tomcat 启动闪退问题解决集(八大类详细)

2

5218ac5338014f389c21bdf1bfa1c599.png

​​​​

Tomcat端口配置(详细)

1

fffa2098008b4dc68c00a172f67c538d.png

​​​​

Tomcat10 安装(Windows环境)(详细)

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

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

相关文章

反光板导航SLAM(三)反光柱导航开发与实验

在上一章中简单了解了VEnus算法对于反光柱导航的基本思路。其主要分为了高反点提取、高反点聚类查找中心、高反点与已知反光柱位姿匹配以及调用ceres库进行位姿优化等步骤。然后在这个算法的基础上&#xff0c;再进行一定的开发达到一个比较稳定且可视化的版本。 使用&#xff…

json对象和formData相互转换

前言 大家都知道&#xff0c;前端在和后台进行交互联调时&#xff0c;肯定避免不了要传递参数&#xff0c;一般情况下&#xff0c;params 在 get 请求中使用&#xff0c;而 post 请求下&#xff0c;我们有两种常见的传参方式&#xff1a; JSON 对象格式和 formData 格式&#x…

《MySQL学习》 索引 下 覆盖索引,MRR,联合索引

一. 覆盖索引 有一张表T1&#xff0c;它的建表语句如下 mysql> create table T1 ( ID int primary key, k int NOT NULL DEFAULT 0, s varchar(16) NOT NULL DEFAULT , index k(k)) engineInnoDB;insert into T1 values(100,1, aa),(200,2,bb),(300,3,cc),(500,5,ee),(60…

为什么子进程要继承处理器亲缘性?

请先考虑一个典型的程序为什么需要启动一个子进程。(当然资源管理器不算一个典型的程序) 这是因为手头的任务被分解为子任务&#xff0c;无论出于何种原因&#xff0c;这些子任务都被放入子流程中。例如&#xff0c;在实现多次遍历型编译器/链接器时&#xff0c;其中每次遍历都…

虹科新品 | 万兆车载以太网媒体转换器-实现更加快捷、高效的连接

多千兆车载以太网 媒体转换器 —— Technica Engineering —— 2.5/5/10GBASE-T1多千兆 Media Converter Media Converter 是一种硬件设备&#xff0c;可在汽车以太网连接&#xff08;100BASE-T1 或 1000BASE-T1&#xff09;和任何具有带 RJ-45 连接器的标准以太网网络接口卡 …

canal同步mysql数据到kafka, kafka消费存入clickhouse

环境win mysql5.7 apache-zookeeper-3.5.9-bin kafka_2.11-1.1.1 canal.deployer-1.1.7-SNAPSHOT 如果不想看步骤可以直接下载我打包好的文件&#xff0c;修改相关数据库配置就行 https://download.csdn.net/download/weixin_38738049/87441074?spm1001.2014.3001.55031新增m…

pytorch 实现情感分类问题

1、词表映射无论是深度学习还是传统的统计机器学习方法处理自然语言&#xff0c;都需要先将输入的语言符号&#xff08;通常为标记Token&#xff09;&#xff0c;映射为大于等于0、小于词表大小的整数&#xff0c;该整数也被称作一个标记的索引值或下标。vocab类实现标记和索引…

C语言(按位运算符和位移运算符)

目录 ​编辑 一.按位运算符 1.二进制反码或按位取反&#xff1a;~ 2.按位与&#xff1a;& 3.按位或&#xff1a;| 4.按位异或&#xff1a;^ 二.位移运算符 1.左移&#xff1a; << 2.右移&#xff1a; >> 一.按位运算符 C有四个按位逻辑运算符都用于整…

[多线程进阶]CAS与Synchronized基本原理

专栏简介: JavaEE从入门到进阶 题目来源: leetcode,牛客,剑指offer. 创作目标: 记录学习JavaEE学习历程 希望在提升自己的同时,帮助他人,,与大家一起共同进步,互相成长. 学历代表过去,能力代表现在,学习能力代表未来! 目录: 1.CAS 1.1 什么是CAS? 1.2 CAS伪代码 1.3 CAS …

【C++初阶】vector的使用

大家好我是沐曦希&#x1f495; 文章目录一.vector介绍二、构造函数三、遍历1.[]2.迭代器3.范围for四、容量操作1.扩容机制五、增删查改六、迭代器失效问题一.vector介绍 vector是表示可变大小数组的序列容器。就像数组一样&#xff0c;vector也采用的连续存储空间来存储元素。…

【Git】如何修改本地仓库的用户名和邮箱

最近我修改了我gitee和github的用户名还有邮箱&#xff0c;所以需要对本地仓库配置的用户名和邮箱进行更改 本文首发于 慕雪的寒舍 1.命令 刚开始我使用的是如下命令 git config --global user.email "邮箱" git config --global user.name "用户名"但是…

机器学习基础总结

一&#xff0c;机器学习系统分类 机器学习系统分为三个类别&#xff0c;如下图所示: 二&#xff0c;如何处理数据中的缺失值 可以分为以下 2 种情况&#xff1a; 缺失值较多&#xff1a;直接舍弃该列特征&#xff0c;否则可能会带来较大噪声&#xff0c;从而对结果造成不良影…

【云原生】promehtheus整合grafana实现可视化监控实战

文章目录前言一. 实验环境二. 安装grafana2.1 grafana的介绍2.2 为什么选择grafana&#xff1f;2.3 grafana下载及安装三. 网页端配置grafana3.1 浏览器访问grafana网页3.2 使用grafana 获取prometheus的数据源3.3 grafana导入prometheus模板总结前言 大家好&#xff0c;又见面…

新出海品牌必看!Colorkey如何构建海外第二增长曲线 ?

根据中商产业研究院数据&#xff0c;2022年1-6月中国美容化妆品及洗护用品出口量484138吨&#xff0c;同比增长8.6%&#xff0c;并且在2022年下半年依然保持强劲的增长。国货美妆品牌出海成为大趋势&#xff0c;各大品牌都纷纷开始出海&#xff0c;寻找新的增长点。Colorkey珂拉…

第二部分:并列句

想要表达一件事&#xff0c;一个简单句即可&#xff0c;一主一谓&#xff0c;n. v. 那&#xff0c;想要表达两件事&#xff0c;就写两个简单句呗&#xff0c;以此类推&#xff0c;想要描述几件事&#xff0c;就写几个简单句就行 英语是形合语言&#xff0c;形式上需要加上连接…

tomcat:设计模式用的好,下班就能早

tomcat作为一款经典的轻量级应用服务器&#xff0c;自然也使用了很多优雅的设计模式。 今天给大家简单介绍一下tomcat在初始化组件时使用的几种设计模式。 组合模式 在tomcat中&#xff0c;把不同的功能设计为了不同的组件&#xff0c;比如connector、engine、host、context等…

推荐五款实用的良心软件,无广告无弹窗

分享是一种神奇的东西,它使快乐增大,它使悲伤减小。 1.拼音输入法——手心输入法 如果你曾被输入法软件的弹屏骚扰&#xff0c;如果你仅需纯粹输入法不需要冗余功能&#xff0c;手心输入法将是你最好的选择&#xff0c;界面清爽简洁&#xff0c;无广告&#xff0c;精准的预测输…

CSI Tool 安装及配置记录

一、Ubuntu安装 1.下载Ubuntu 首先安装Ubuntu 14.04 LTS 64位下载地址&#xff08;页面中第一个链接&#xff09; 2.制作启动盘&#xff08;注意备份&#xff09; 可以使用官方的工具Rufus&#xff0c;下载地址&#xff1a;https://rufus.ie/ 打开Rufus&#xff0c;先备份…

wav转mp3,wav转换成mp3教程

很多使用音频文件的小伙伴&#xff0c;总会接触到不同类型的音频格式&#xff0c;根据需求不同需要做相关的处理。比如有人接触到了wav格式的音频&#xff0c;这是windows系统研发的一种标准数字音频文件&#xff0c;是一种占用磁盘体积超级大的音频格式&#xff0c;通常用于录…

超级好用的json格式化工具

理想的json格式化工具应该具备什么&#xff1f;你心中的json格式化工具是什么&#xff1f; Json.cn? No No No, 这个已经老掉牙了理想的json格式化工具应该支持搜索、定位、非法json容错&#xff0c;若实在无法格式化则应该给出具体的错误位置&#xff0c;并且可视区要大&…