ホームページ >ウェブフロントエンド >jsチュートリアル >jQuery の力を解き放ち、ツールチップを強化します

jQuery の力を解き放ち、ツールチップを強化します

WBOY
WBOYオリジナル
2023-09-04 16:09:01975ブラウズ

title 属性を指定すると、ブラウザーはツールチップを自動的に表示します。 Internet Explorer も alt 属性を使用します。ただし、このチュートリアルでは、一般的なブラウザーのツールチップをより派手なものに置き換える jQuery プラグインをすばやく作成する方法を説明します。

释放 jQuery 的力量来增强您的工具提示

Web 開発グッズ パッケージで最も役立つツールの 1 つは、ツール ヒントです。ツールチップはボックスです

ハイパーリンクなどの要素の上にカーソルを置くと表示されます。補足を提供します

この要素に関する情報。たとえば、リンクにテキスト (アイコン) がほとんどまたはまったく含まれていないと、わかりにくくなる可能性があります。

ヒントをクリックすると何が起こるかをユーザーに説明する追加の文をツールヒントに 1 つか 2 つ追加します。


開始前

このチュートリアルは中級のカテゴリに分類される可能性があります。この手順では、少なくとも

があることを前提としています。 HTML/CSS、スライス手法、jQuery の基本的な理解。

jQuery について復習が必要な場合は、次の推奨 Web サイトを参照してください:

  • 完全初心者のための jQuery: ビデオ シリーズ
  • カスタム WordPress プラグインを最初から作成する
  • jQuery をゼロから始めるのに役立つ 15 のリソース
  • jQuery と JavaScript のコーディング: 例とベスト プラクティス
  • jQuery 入門
  • 欲しいものを何でも手に入れる方法 - パート 1

このチュートリアルに関連するファイルを明確に理解できるように、ファイル構造は次のようになります

終わったときのように。

释放 jQuery 的力量来增强您的工具提示

各ファイル/フォルダーの概要は次のとおりです:

  • Images フォルダーには次の画像が含まれています:
  • - - tipTip.png -
  • 手順 2 で作成
  • - - tipMid.png -
  • 手順 2 で作成
  • - - tipBtm.png -
  • 手順 2 で作成
  • index.html - - 手順 3 で
  • を作成しました
  • style.css - 手順 3 で
  • を作成しました
  • jquery-1.3.1.min.js - ここからダウンロードします
  • jquery.betterTooltip.js - - 手順 5 で作成します

ステップ 1 - まず、少し創造的になりましょう

Photoshop または選択したソフトウェアを開いて、美しいツールチップを作成します。デザインというよりも

# 無地の白い背景に、Web サイトと同じような背景にツールチップを描画すると便利な場合があります。

こうすることで、シームレスに融合します。ほとんどの場合、正しい方法も間違った方法もありません

このステップを完了するには、想像力と創造性を発揮してください。

释放 jQuery 的力量来增强您的工具提示


ステップ 2 - スライスとダイシングのツールチップ

この特定のデザインでは、ツールチップを 3 つの異なる画像に分割する必要があります。この特定のデザインでは、透明度を維持するために PNG が必要です。

1) 一番上の部分。 2) 中央で垂直に繰り返される薄い 1 ピクセルのスライス。 3) 底部。以下の画像の 4 番目の部分は、これら 3 つの

を示しています。 部分を切り出します。

これらの画像ファイルを「images」というフォルダーに置きます。

释放 jQuery 的力量来增强您的工具提示

注: Internet Explorer は PNG 透明度を好みません。 IE 7 でも部分的にしかサポートされていません。アニメーションを作るなら

PNG と JavaScript では、透明な領域を移動するとすぐに黒くなります。私はこのデザインを使用しています

IE で困難な問題が発生することを十分に承知してください。


ステップ 3 - HTML/CSS マークアップを作成する

画像がスライスされた後、HTML および CSS マークアップの処理を続けることができます。これはプロセス全体の中で最も簡単な部分です

チュートリアル。

HTML

この HTML タグはまもなく外部 JavaScript ファイルに移動されるため、これを任意の場所に入力してください

最も便利で、将来的に参照できます。

リーリー

div タグは 3 つあります。どちらも親オブジェクト内にネストされています。最初の div、「tip」はすべてを結び付けるために使用されます

そして、ツールチップの上部、

tipTop.png が表示されます。

"tipMid" は、最終的にツールチップに表示されるテキストを保持します。また、その中で

tipMid.png が垂直方向に繰り返されます。

「tipBtm」は、ツールチップの下部 (

tipBtm.png) を表示するためにのみ使用されます。

index.html 内に、大量のパディング テキストと、title 属性が入力されたいくつかの要素を追加します。のように:### リーリー

index.html

の先頭では、スタイルシートと 2 つの JavaScript ファイルにリンクする必要があります。

	<link href="style.css" rel="stylesheet" type="text/css" media="all" />
	<script type="text/javascript" src="jquery-1.3.1.min.js"></script>
	<script type="text/javascript" src="jquery.betterTooltip.js"></script>

CSS

这个工具提示使用的CSS比较简单,只需将以下内容添加到style.css

	.tip {
		width: 212px;
		padding-top: 37px;
		display: none;
		position: absolute;
		background: transparent url(images/tipTop.png) no-repeat top;}

	.tipMid {background: transparent url(images/tipMid.png) repeat-y; padding: 0 25px 20px 25px;}
	.tipBtm {background: transparent url(images/tipBtm.png) no-repeat bottom; height: 32px;}

让我解释一下上面的内容。

包装元素 .tip 用于将所有内容固定在一起。它的顶部内边距为 37 像素。

这是背景图像的高度。填充会将子元素向下推以显示

后面的图像。它还具有绝对位置,以便我们可以将其在页面顶部移动

内容。

另外两个类仅具有背景图像,并且在 .topMid 的情况下,通过填充来提供

将放置在里面的内容,一些呼吸的空间。


第 4 步 - 为什么使用插件?

jQuery 本身就非常酷。但真正的魔力在于使用插件扩展它。当你把你的 将代码写入插件,就可以使其可重用。这样你就可以构建一个代码库而无需编写

相同的代码两次。

这是完整的工具提示插件:

	$.fn.betterTooltip = function(options){

		/* Setup the options for the tooltip that can be 
		   accessed from outside the plugin              */
		var defaults = {
			speed: 200,
			delay: 300
		};

		var options = $.extend(defaults, options);

		/* Create a function that builds the tooltip 
		   markup. Then, prepend the tooltip to the body */
		getTip = function() {
			var tTip = 
			"<div class='tip'>" +
				"<div class='tipMid'>"	+
				"</div>" +
				"<div class='tipBtm'></div>" +
			"</div>";
			return tTip;
		}
		$("body").prepend(getTip());

		/* Give each item with the class associated with 
		   the plugin the ability to call the tooltip    */
		$(this).each(function(){

			var $this = $(this);
			var tip = $('.tip');
			var tipInner = $('.tip .tipMid');
			
			var tTitle = (this.title);
			this.title = "";
			
			var offset = $(this).offset();
			var tLeft = offset.left;
			var tTop = offset.top;
			var tWidth = $this.width();
			var tHeight = $this.height();
	
			/* Mouse over and out functions*/
			$this.hover(function() {
				tipInner.html(tTitle);
				setTip(tTop, tLeft);
				setTimer();
			}, 
			function() {
				stopTimer();
				tip.hide();
			}
		);		   
	
		/* Delay the fade-in animation of the tooltip */
		setTimer = function() {
			$this.showTipTimer = setInterval("showTip()", defaults.delay);
		}
	
		stopTimer = function() {
			clearInterval($this.showTipTimer);
		}
	
		/* Position the tooltip relative to the class 
		   associated with the tooltip                */
		setTip = function(top, left){
			var topOffset = tip.height();
			var xTip = (left-30)+"px";
			var yTip = (top-topOffset-60)+"px";
			tip.css({'top' : yTip, 'left' : xTip});
		}
	
		/* This function stops the timer and creates the
		   fade-in animation                          */
		showTip = function(){
			stopTimer();
			tip.animate({"top": "+=20px", "opacity": "toggle"}, defaults.speed);
		}
	});
};

第 5 步 - 编写插件

现在您已经了解了代码的样子,是时候剖析它了。

首先,创建一个 .js 文件并将其命名为 jquery.betterTooltip.js 以使其与 jQuery 兼容

插件标准。

在该 .js 文件中,包含以下代码:

	$.fn.betterTooltip = function(){

	});

这将创建一个公共函数,可以从文档的 head 调用,或者

另一个外部 .js 文件。要调用您的插件,您需要从

中调用以下行 $(document).ready 页面事件。

	$(document).ready(function(){
		$('.tTip').betterTooltip();
	});

上面的行会将插件附加到类名为“tTip”的每个元素。同样,你

可以将其附加到您选择的任何元素。

公开插件设置

为了避免必须为每个项目修改插件,公开一些内容非常重要

变量和设置,以便可以从插件本身外部对其进行调整。最终目标是

永远不要碰插件,只需调整其设置即可。为此,请将以下内容添加到第一个块

代码:

	$.fn.betterTooltip = function(options){
		/* Setup the options for the tooltip that can be 
		   accessed from outside                      */
		   
		var defaults = {
			speed: 200,
			delay: 300
		};

		var options = $.extend(defaults, options);
	});

这允许在调用插件时修改设置“速度”和“延迟”,如下所示:

	$('.tTip').betterTooltip({speed: 600, delay: 600});

这些完全是可选的。如果未指定,插件将使用默认值。

注入工具提示标记

还记得您为工具提示输入的 HTML 吗?现在它将正式亮相。

在这段代码中,jQuery“前置”内容操作用于注入工具提示

紧接着打开 body 标签。这样我们就可以确保工具提示

位于一切之上。

	/* Create a function that builds the tooltip 
	   markup. Then, prepend the tooltip to the body */
	getTip = function() {
		var tTip = 
		"<div class='tip'>" +
			"<div class='tipMid'>"	+
			"</div>" +
			"<div class='tipBtm'></div>" +
		"</div>";
		return tTip;
	}
	$("body").prepend(getTip());

$(this).each 函数

这是 jQuery 插件最重要和最有用的方面之一。 $(this).each 函数

当插件被调用时,循环遍历与插件关联的每个页面元素。在本例中是

所有具有“tTip”类的元素。当它循环遍历每个元素时,它会应用属性和方法

您指定的。

	$(this).each(function(){

		var $this = $(this);
		var tip = $('.tip');
		var tipInner = $('.tip .tipMid');
		
		var tTitle = (this.title);
		this.title = "";
		
		var offset = $(this).offset();
		var tLeft = offset.left;
		var tTop = offset.top;
		var tWidth = $this.width();
		var tHeight = $this.height();

		/* Mouse over and out functions*/
		$this.hover(function() {
			tipInner.html(tTitle);
			setTip(tTop, tLeft);
			setTimer();
		}, 
		function() {
			stopTimer();
			tip.hide();
		}
	);

这相当简单。上半部分由一系列属性组成,例如高度、宽度、x 和 y 位置以及

甚至“tTip”元素的标题属性值。我使用 jQuery offset() CSS 方法来获取顶部和左侧位置。还有一个

分配给每个“tTip”类的悬停函数,该函数在鼠标悬停和移出时调用方法。下面将介绍这些方法

further down in the 教程。

$(this).each 函数的一个重要部分是这里删除 title 属性的这行代码:

	this.title = "";

此工具提示的重点是交换通用

工具提示具有更好的引人注目的版本。如果不删除 title 属性,浏览器会显示

用于生成通用工具提示,您将获得双重工具提示。像这样:

释放 jQuery 的力量来增强您的工具提示

延迟工具提示的淡入动画

		/* Delay the fade-in animation of the tooltip */
		setTimer = function() {
			$this.showTipTimer = setInterval("showTip()", defaults.delay);
		}
	
		stopTimer = function() {
			clearInterval($this.showTipTimer);
		}

setTimer 和 stopTimer 这两个方法用于在用户悬停时创建延迟

他们的光标悬停在具有“tTip”类的元素上以及工具提示出现时。这个

避免烦扰用户很重要。我相信当我们不小心悬停时,我们都会感到沮丧

隐藏在网站内容中的弹出广告之一。

setTimer 方法创建一个 setInterval 对象,该对象在分配的时间过去后调用“showTip()”。

为了让setInterval不至于无限循环,调用stopTimer方法来停止setInterval对象。

定位工具提示

		/* Position the tooltip relative to the class 
		   associated with the tooltip                */
		setTip = function(top, left){
			var topOffset = tip.height();
			var xTip = (left-30)+"px";
			var yTip = (top-topOffset-60)+"px";
			tip.css({'top' : yTip, 'left' : xTip});
		}

之前创建的 $(this).each 循环内的悬停函数调用 setTip()。其目的是定位

“tTip”元素正上方的工具提示。这是在淡入动画之前完成的。

工具提示淡入动画

		/* This function stops the timer and creates the
		   fade-in animation                          */
		showTip = function(){
			stopTimer();
			tip.animate({"top": "+=20px", "opacity": "toggle"}, defaults.speed);
		}
	});
};

最后但并非最不重要的一点是 showTip() 函数。这使用 jQuery 的 animate() UI 效果来淡入淡出工具提示

同时向下滑动。


总结一下。 。 .

完成并对结果感到满意后,您可以将插件从充满填充文本的基本 HTML 页面移动到

现实世界并加以利用。

これは、ツールチップ プラグインが行うことの非常に基本的な例です。ここで楽しいのは、それをより堅牢にすることです。

このプラグインを拡張するには複数の方法があります。必要な機能強化は、

を検出することです。 ブラウザ ウィンドウの境界を基準にしてツールチップを配置し、それに応じてツールチップを表示します

切れることはありません。

このチュートリアルをお読みいただきありがとうございます。 jQuery を使用して Web サイトを強化する方法についてのアイデアが得られれば幸いです

インターフェース。

コメントを始めます!あなたの考えを聞きたいです。このテクノロジーは本当にユーザーの利便性を高めるのに役立つのでしょうか?

それとも、これは単なる迷惑なのでしょうか?

  • NETTUTS RSS フィードを購読して、毎日の Web 開発チュートリアルや記事をご覧ください。

以上がjQuery の力を解き放ち、ツールチップを強化しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。