ホームページ >ウェブフロントエンド >htmlチュートリアル >html5 には新しい属性がありますか?

html5 には新しい属性がありますか?

青灯夜游
青灯夜游オリジナル
2021-05-20 15:51:263255ブラウズ

html5 には、contextmenu、contentEditable、hidden、draggable、「data-*」、placeholder、required、pattern、autofocus、autocomplete などの新しい属性があります。

html5 には新しい属性がありますか?

このチュートリアルの動作環境: Windows 7 システム、HTML5 バージョン、Dell G3 コンピューター。

HTML5 の新しい属性

1.1、contextmenu

contextmenu の機能は、右クリック メニューを指定することです。

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
    </head>
    <body>
        <div id="div1" style="height:900px; background: lightgreen;" contextmenu="menuShare">
        </div>
        <menu id="menuShare" type="context">
            <menuitem label="分享到QQ空间" onclick="alert(&#39;QQ&#39;);"></menuitem>
            <menuitem label="分享到朋友圈" onclick="alert(&#39;朋友圈&#39;);"></menuitem>
            <menuitem label="分享到微博" onclick="alert(&#39;微博&#39;);"></menuitem>
        </menu>
    </body>
</html>

実行効果:

contextmenu Html5 では、各要素に新しい属性がある: contextmenu。contextmenu はコンテキスト メニュー、つまり右クリックです。マウス 要素のメニューが表示されます。
menu 要素を右クリックするとメニューが表示されることを理解するには、HTML5 の別の新しい要素である menu についても理解する必要があります。名前が示すように、menu はメニューを定義します。menu 要素の属性: type: メニュー タイプ属性。 3 つの値があります 1) context: context; 2) toolbar: ツールバー; 3) list: list
9b8d7b889acba92c978f783c55ba01dc
5c0e96d12fc7501cef2ae2efde646ee0 5a9a0e9117a868e744002d2d9e892511メニュー項目は内部に埋め込むことができますつまり、< ;menuitem>89a5789a3f15e118e2e41278ab35ace0です。
menuitem 属性:
label: メニュー項目によって表示される名前
icon: メニュー項目の左側に表示されるアイコン
onclick: メニュー項目をクリックすることによってトリガーされるイベント

1.2 、contentEditable

要素のコンテンツを編集できるかどうかを指定します
属性値:
true -----要素のコンテンツは編集できます。 edit
false -----要素は編集できません Content
inherit -----親要素の contenteditable 属性を継承します
空文字列の場合、効果は true と同じです。
要素の contenteditable ステータスが true (contenteditable 属性が空の文字列、true、または継承で親要素のステータスが true) の場合、要素が編集可能であることを意味します。それ以外の場合、要素は編集できません。

document.body.contentEditable=true; 公開された Web サイトを変更できます

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title>contentEditable属性</title>
    </head>
    <body>
        <h2>contentEditable属性</h2>
        <div contenteditable="true">
            Hello contentEditable
        </div>
    </body>
</html>

1.3、hidden

hidden 属性は要素を非表示にするために使用されます。この属性を使用すると、要素はブラウザに表示されなくなります。
2 ブール値
true は、要素が表示されることを指定します。
false は、要素が非表示であることを指定します。

        <div hidden="hidden">
            Hello Hidden
        </div>

この属性をサポートしていない一部のブラウザ (IE8) と互換性を持たせるために、次のスタイルを CSS に追加できます:

*[hidden]{
   display: none;
}
var p1=document.querySelector("body #p1");
p1.innerHTML+=" +++";

1.4、draggable

要素をドラッグできるかどうかを指定します
3 列挙値
true は要素がドラッグできるかどうかを指定します。
false は、要素がドラッグできないことを指定します。
auto はブラウザのデフォルト機能を使用します。

例:

<!DOCTYPE html><html>

    <head>
        <meta charset="utf-8">
        <script src="Scripts/jquery-1.11.3.min.js" type="text/javascript" charset="utf-8"></script>    
        <title></title>
        <style>
            #p1,
            #p3 {
                height: 200px;
                width: 200px;
                border: 1px solid #00f;
                margin-bottom: 10px;
            }
            #p2 {
                height: 100px;
                width: 100px;
                background: yellow;
            }
        </style>
        <script>
            var p1, p2, p3, msg;
            window.onload = function() {
                p1 = document.getElementById("p1");
                p2 = document.getElementById("p2");
                p3 = document.getElementById("p3");
                msg = document.getElementById("msg");
                
                p2.ondragstart=function(){
                    msg.innerHTML+="p2开始拖动了<br/>";
                }
                p2.ondrag=function(){
                    msg.innerHTML+="拖动中<br/>";
                }
                p2.ondragend=function(){
                    msg.innerHTML+="拖动结束<br/>";
                }
                
                p1.ondragover = function(e) {
                    e.preventDefault();
                }
                p1.ondrop = function(e) {
                    p1.appendChild(p2);
                }
                p3.ondragover = function(e) {
                    e.preventDefault();
                }
                p3.ondrop = function(e) {
                    p3.appendChild(p2);
                }
                
                $("#p1").data("name","电池");
                alert($("#p1").data("name"));
                
                p1.setAttribute("data-order-price",998.7);
                alert(p1.getAttribute("data-order-price"));
            }        </script>
    </head>

    <body>
        <p id="p1" data-order-price="98.5" data-name="充电宝"></p>
        <p id="p3"></p>
        <p id="p2" draggable="true"></p>
        <h3 id="msg"></h3>
    </body></html>

実行結果:

<!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>
    <p style="height: 300px; background: lightgoldenrodyellow;"  ondrop="ondropEvent(event)" ondragover="ondragoverEvent(event)"></p>
    <img src="img/x.png" width="200" draggable="true" ondragstart="ondragstartEvent(event)"/>
    <img src="img/tv.png" width="200" draggable="true" ondragstart="ondragstartEvent(event)"/>
    <script>
        var target;        function ondragstartEvent(e){
            target=e.target;            //记住当前被拖动的对象            console.log(e.target);
        }        function ondropEvent(e){
            e.preventDefault();
            e.target.appendChild(target);

        }        function ondragoverEvent(e){
            e.preventDefault();
        }    </script></body></html>

##1.5, data- *

data-*attribute を使用すると、ユーザーはカスタマイズされた属性の形式でデータを保存できます

8be402465d07248b2b2c6d5cd6cae86e54bdf357c58b8a65c66d7c19c8e4d114
値:
getAttribute('data-order-amount')
dataset.orderAmount
jQuery の data() メソッドにもアクセスできます

jQuery と JavaScript を使用してデータ属性を追加および取得する例:

<!DOCTYPE html><html>
    <head>
        <meta charset="UTF-8">
        <title>data-*</title>
        <script src="js/jquery-1.11.3.min.js" type="text/javascript" charset="utf-8"></script>
    </head>
    <body>
        <h2>data-*</h2>
        <p id="p1" data-student-name="Tom" data-stu=&#39;{"a":1,"b":2}&#39;></p>
        <button onclick="addData()">添加数据</button>
        <button onclick="getData()">获取数据</button>
        <script type="text/javascript">
            var p1=document.getElementById("p1");            function addData()
            {                //给p1添加属性data-student-name,值为rose                p1.setAttribute("data-student-name","Rose");
                $("#p1").data("stu-mark","99分");
            }            function getData()
            {                //原生JavaScript
                //alert(p1.getAttribute("data-student-name"));
                
                //jQuery                alert($("#p1").data("student-name"));
                alert($("#p1").data("stu").a);
                alert($("#p1").data("stu-mark"));
            }            
            
            var x="{a:1}";
            alert(eval("("+x+")").a);        </script>
    </body></html>

実行効果:

1.6、プレースホルダー属性

これは非常に実用的な属性です。フォームの初期値をクリアするためのクリックを実現するために JS を使用する必要はありません。ブラウザのサポートも非常に優れています。Firefox に加えて、他の標準ブラウザも十分にサポートできます。

a17308fcb41f110fde352856549d4db4

该属性默认是打开的。

1.11、novalidate不验证属性

novalidate 属性规定在提交表单时不应该验证 form 或 input 域。

<form action="demo_form.asp" method="get" novalidate="true">
<button formnovalidate="formnovalidate" >提交</button>

1.12、multiple多选属性

multiple 属性规定输入域中可选择多个内容,如:email 和 file

2c932e4b50e0cc404ddcc4029809dc63

            e388a4556c0f65e1904146cc1a846bee
                2e1cf0710519d5598b1f0f14c36ba674相片:8c1ecd4bb896b2264e0711597d40766c
                429fe2bf8b5acc4451d224c4b72fc98c
            94b3e26ee717c64999d7867364b1b4a3

<!DOCTYPE html><html>

    <head>
        <meta charset="UTF-8">
        <title>HTML5新的表单元素</title>
    </head>

    <body>
        <h2>HTML5新的表单元素</h2>
        <form>
            <p>
                <label>姓名:</label>
                <input type="text" required="required"/>
            </p>
            <p>
                <label>相片:</label>
                <input type="file" multiple="multiple"/>
            </p>
            <p>
                <label>帐号:</label>
                <input type="text" name="username" autocomplete="on" required="required" pattern="^[0-9a-zA-Z]{6,16}$" />请输入a-zA-Z0-9且长度6-16位的字符            </p>
            <p>
                <label>邮箱:</label>
                <input type="email" name="mail" id="mail" value="" placeholder="请输入邮箱"/>
            </p>
            <p>
                <label>博客:</label>
                <input type="url" name="blog" id="blog" value="" required="required" autofocus="autofocus"/>
            </p>
            <p>
                <label>生日:</label>
                <input type="date">
            </p>
            <p>
                <label>身高:</label>
                <input type="number" max="226" min="80" step="10" value="170" />
            </p>
            <p>
                <label>肤色:</label>
                <input type="color" onchange="document.bgColor=this.value" />
            </p>
            <p>
                <label>体重:</label>
                <input type="range" max="500" min="30" step="5" value="65" onchange="showValue(this.value)"/>
                <span id="rangeValue"></span>
            </p>
            <button formnovalidate="formnovalidate">提交</button>
            <script type="text/javascript">
                function showValue(val){
                    document.getElementById("rangeValue").innerHTML=val;
                }            </script>
        </form>
    </body></html>

推荐教程:html视频教程

以上がhtml5 には新しい属性がありますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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