javascript基於DOM實現許可權選擇執行個體分析

來源:互聯網
上載者:User

javascript基於DOM實現許可權選擇執行個體分析

   本文執行個體講述了javascript基於DOM實現許可權選擇的方法。分享給大家供大家參考。具體實現方法如下:

  ?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<title>許可權選擇</title>

<script type="text/javascript">

//====================多選操作====================================

function selMultiple(selectSrc, selectDes) {

for (var i = selectSrc.childNodes.length - 1; i >= 0; i--) {

var option = selectSrc.childNodes[i];

if (option.selected == true) {

selectSrc.removeChild(option);

option.selected = false;

selectDes.appendChild(option);

}

}

}

function selectToRight() {

var selectSrc = document.getElementById("select1");

var selectDes = document.getElementById("select2");

selMultiple(selectSrc, selectDes);

}

function selectToLeft() {

var selectSrc = document.getElementById("select2");

var selectDes = document.getElementById("select1");

selMultiple(selectSrc, selectDes);

}

//====================全選操作====================================

function selAll(selectSrc, selectDes) {

// 這種寫法有問題,發現selectSrc.childNodes.length居然等於10,實際上只有5個元素

// for (var i = 0; i < selectSrc.childNodes.length; i++) {

// var option = selectSrc.childNodes[0];

// selectSrc.removeChild(option);

// selectDes.appendChild(option);

// }

var options = selectSrc.getElementsByTagName("option");

var optLength = options.length;

/*

注意:for迴圈中不能直接使用options.length,因為selectDes.appendChild執行後

會導致options.length減一,所以先把options.length存放到一個變數中備用

*/

for (var i = 0; i < optLength; i++) {

var option = options[0]; //這裡使用的始終是第0個元素

selectDes.appendChild(option);

}

selectSrc.options.length = 0;

}

function selectToRightAll() {

var selectSrc = document.getElementById("select1");

var selectDes = document.getElementById("select2");

selAll(selectSrc, selectDes);

}

function selectToLeftAll() {

var selectSrc = document.getElementById("select2");

var selectDes = document.getElementById("select1");

selAll(selectSrc, selectDes);

}

</script>

</head>

<body>

<select id="select1" multiple="multiple" style="float:left;width:100px;height:200px;">

<option>添加</option>

<option>刪除</option>

<option>修改</option>

<option>儲存</option>

<option>查詢</option>

</select>

<div style="float:left;width:50px;">

<input type="button" style="float:left;width:100%;" value=">" onclick="selectToRight()" />

<input type="button" style="float:left;width:100%;" value="<" onclick="selectToLeft()" />

<input type="button" style="float:left;width:100%;" value=">>" onclick="selectToRightAll()" />

<input type="button" style="float:left;width:100%;" value="<<" onclick="selectToLeftAll()" />

</div>

<select id="select2" multiple="multiple" style="float:left;width:100px;height:200px"></select>

</body>

</html>

  希望本文所述對大家的javascript程式設計有所協助。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.