1. 수요
아래와 같이
진행률 표시줄을 구현하는 것이 핵심입니다.
2. 분석
"html5에서 태그 추가 및 삭제" 기사에서 html5에 새로운 진행 태그가 추가되었다고 언급되었습니다. 하지만 확실히 호환성 문제가 있습니다. 프로덕션 환경이 적합하지 않으므로 구현을 시뮬레이션해야 합니다.
원리:
의 하위 요소 의 너비 값을 동적으로 설정합니다.
1. 간단한 프로토타입
아래와 같이 진행률 표시줄이 하나만 있다고 가정합니다. 브라우저가 로드될 때 p 요소의 너비와 범위 요소의 백분율만 알면 됩니다. 진행률 표시줄의 효과를 얻기 위해 범위의 너비를 동적으로 설정할 수 있습니다.
<style> .long{width:100px;border:1px solid #7f7f7f;height:14px;background-color:#d6d6d6;} .short{float:left;height:14px;background-color:#0FF;} </style> <body> <P class="long"><span class="short"></span></P> <script src="http://code.jquery.com/jquery-latest.js"></script> <script> var percent=0.5; var longWidth=100; var shortWidth=percent*longWidth; $(".short").animate({width:shortWidth+"px"},'slow'); </script> </body>
2. 투표 진행 표시줄 구현 과정
1단계: 구조는 다음과 같습니다
<meta charset="utf-8"> <style> /*样式重置*/ ul,h4,p{margin:0;padding:0;} /*清除浮动*/ .clearfix:after{visibility:hidden;display:block;font-size:0;content:" ";clear:both;height:0;} body { font: 12px/1.5 arial, 宋体; } html, body { color: #333333; } /*投票css*/ .vote-box-list{border:1px solid red;position:absolute;} .vote-box-list li{list-style:none;margin:10px 0;} .vote-item-wrap h4,.vote-item-wrap .vnum{float:left;font-size:14px;font-weight:normal;line-height:16px;} .vote-item-wrap p{float:left;height:14px;width:200px;border:1px solid #E2E2E2;background-color:#EFEFEF;margin:0 10px;} .vote-item-wrap p span{float:left;height:14px;/*width:30px;background-color:#c2f263;*/} </style> <ul class="vote-box-list clearfix" id="appVoteBox"> <li class="vl-item" id="voteItem0"> <div class="vote-item-wrap clearfix"> <h4 id="A">A:</h4> <p class="litem"><span></span></p> <span class="vnum">79(2%)</span> </div> </li> <li class="vl-item" id="voteItem1" > <div class="vote-item-wrap clearfix"> <h4 id="B">B:</h4> <p class="litem"><span></span></p> <span class="vnum">1986(61%)</span> </div> </li> <li class="vl-item" id="voteItem2"> <div class="vote-item-wrap clearfix"> <h4 id="C">C:</h4> <p class="litem"><span></span></p> <span class="vnum">1153(36%)</span> </div> </li> <li class="vl-item" id="voteItem3" > <div class="vote-item-wrap clearfix"> <h4 id="D">D:</h4> <p class="litem"><span></span></p> <span class="vnum">415(13%)</span> </div> </li> <li class="vl-item" id="voteItem4" > <div class="vote-item-wrap clearfix"> <h4 id="E">E:</h4> <p class="litem"><span></span></p> <span class="vnum">89(3%)</span> </div> </li> </ul>
스팬에 너비와 배경색을 추가하여 진행률 표시줄 효과를 만듭니다. 이 단계는 js를 사용하여 구현됩니다.
두 번째 단계는 js로 스팬 너비를 설정하는 것입니다
<script src="http://code.jquery.com/jquery-latest.js"></script> <script> var Vote={}; Vote.ListShow=(function(){ var longWidth; var percentArr=[]; var shortWidth=[]; var spanArr=[]; /*初始化*/ function init(o){ voteId=o.id; longWidth=o.width; percentArr=o.percent; shortWidth=calWidth(); spanArr=findSpans(); } /*根据百分比计每个算span的实际宽度*/ function calWidth(){ var arr=[]; for(var i=0;i<percentArr.length;i++){ var tempLength=percentArr[i]*longWidth; arr.push(tempLength); } return arr; } /*将全部span存为一个数组*/ function findSpans(){ var litems=$("#"+voteId).find(".litem"); var arr=[] for(var i=0;i<litems.length;i++){ arr.push(litems[i].children[0]); } return arr; } /*每个span元素设置宽度*/ function setWidth(){ for(i=0;i<percentArr.length;i++){ $(spanArr[i]).animate({width:shortWidth[i]+"px"},'slow'); $(spanArr[i]).css({'background-color':"#c2f263"}); } } return {init:init,set:setWidth}; })(); /*调用*/ Vote.ListShow.init( { id:'appVoteBox', width:200-2 , percent:[0.02,0.61,0.36,0.13,0.3], }); Vote.ListShow.set(); </script>
효과:
세 번째 단계, js는 스팬의 배경색을 설정합니다
두 번째 단계의 배경색은 아래와 동일하게 설정됩니다.
$(spanArr[i]).css({'background-color':"#c2f263"}); 现在随机生成背景色,做一个彩色的进度条。 <script src="http://code.jquery.com/jquery-latest.js"></script> <script> var Vote={}; Vote.ListShow=(function(){ var longWidth; var percentArr=[]; var shortWidth=[]; var spanArr=[]; var colorArr=[]; /*初始化*/ function init(o){ voteId=o.id; longWidth=o.width; percentArr=o.percent; shortWidth=calWidth(); spanArr=findSpans(); colorArr=genColor(); } /*根据百分比计每个算span的实际宽度*/ function calWidth(){ var arr=[]; for(var i=0;i<percentArr.length;i++){ var tempLength=percentArr[i]*longWidth; arr.push(tempLength); } return arr; } /*将全部span存为一个数组*/ function findSpans(){ var litems=$("#"+voteId).find(".litem"); var arr=[] for(var i=0;i<litems.length;i++){ arr.push(litems[i].children[0]); } return arr; } /*o是颜色数组,随机选择length种颜色返回*/ function genColor() { var o = []; var n = ["#5dbc5b", "#6c81b6", "#9eb5f0", "#a5cbd6", "#aee7f8", "#c2f263", "#d843b3", "#d8e929", "#e58652", "#e7ab6d", "#ee335f", "#fbe096", "#ffc535"]; //彩色进度条 var colorsArr = n.slice(); for (var i = 0;i < percentArr.length; i++){ //Math.random()返回0.0 ~ 1.0 之间的一个伪随机数。 //Math.floor()向下取整 var k = Math.floor(Math.random()* colorsArr.length); o.push(colorsArr[k]); //取完一种颜色后就从颜色数组中删除 colorsArr.splice(k, 1); if (colorsArr.length == 0){ colorsArr = n.slice()} } return o; } /*每个span元素设置宽度*/ function setWidth(){ for(i=0;i<percentArr.length;i++){ $(spanArr[i]).animate({width:shortWidth[i]+"px"},'slow'); $(spanArr[i]).css({'background-color':colorArr[i]}); } } return {init:init,set:setWidth}; })(); /*调用*/ Vote.ListShow.init( { id:'appVoteBox', width:200-2 , percent:[0.02,0.61,0.36,0.13,0.3], }); Vote.ListShow.set(); </script>
최종 효과:
위는 컬러 진행률 표시줄의 특수 효과로, 특히 투표에 적합합니다. 모든 사람의 학습에 도움이 되기를 바라며 이 컬러 진행률 표시줄을 좋아하실 것입니다.

实现方法:1、用“$("img").delay(毫秒数).fadeOut()”语句,delay()设置延迟秒数;2、用“setTimeout(function(){ $("img").hide(); },毫秒值);”语句,通过定时器来延迟。

区别:1、axios是一个异步请求框架,用于封装底层的XMLHttpRequest,而jquery是一个JavaScript库,只是顺便封装了dom操作;2、axios是基于承诺对象的,可以用承诺对象中的方法,而jquery不基于承诺对象。

修改方法:1、用css()设置新样式,语法“$(元素).css("min-height","新值")”;2、用attr(),通过设置style属性来添加新样式,语法“$(元素).attr("style","min-height:新值")”。

增加元素的方法:1、用append(),语法“$("body").append(新元素)”,可向body内部的末尾处增加元素;2、用prepend(),语法“$("body").prepend(新元素)”,可向body内部的开始处增加元素。

删除方法:1、用empty(),语法“$("div").empty();”,可删除所有子节点和内容;2、用children()和remove(),语法“$("div").children().remove();”,只删除子元素,不删除内容。

在jquery中,apply()方法用于改变this指向,使用另一个对象替换当前对象,是应用某一对象的一个方法,语法为“apply(thisobj,[argarray])”;参数argarray表示的是以数组的形式进行传递。

去掉方法:1、用“$(selector).removeAttr("readonly")”语句删除readonly属性;2、用“$(selector).attr("readonly",false)”将readonly属性的值设置为false。

on()方法有4个参数:1、第一个参数不可省略,规定要从被选元素添加的一个或多个事件或命名空间;2、第二个参数可省略,规定元素的事件处理程序;3、第三个参数可省略,规定传递到函数的额外数据;4、第四个参数可省略,规定当事件发生时运行的函数。


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

Dreamweaver Mac版
시각적 웹 개발 도구

안전한 시험 브라우저
안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.
