JSON.parse ダブルクォーテーションを 解析するとエラーになります。
eval 関数以外の方法はないでしょうか?
{"a":"\u6797\u590f\u8587 Rosina Lam \ufe63 \u5f88\u60f3\u8a0e\u53ad\u4f60 I Wish I Could Hate You (TVB\u5287\u96c6\"\u55ae\u6200\u96d9\u57ce\"\u4e3b\u984c\u66f2) (OFFICIAL AUDIO)","b":"\u6a02\u51e1&\u7941\u9686 - \u611b\"\u4f60\u4e00\"\u751f"}
2016年2月28日日曜日
2016年2月26日金曜日
2016年2月12日金曜日
イメージファイルのオリジナルサイズを確認する
イメージファイルのオリジナルサイズを確認する
.naturalHeight
.naturalWidth
function item_cards_event(){
var x = document.getElementsByClassName('item_cards');
for(var i = 0; i<x.length; i++){
x[i].addEventListener("mouseover",function(e){
this.style.boxShadow = "3px 3px 14px";
console.log(this.firstElementChild.nextElementSibling.firstElementChild.naturalWidth + 'x' + this.firstElementChild.nextElementSibling.firstElementChild.naturalHeight);
},false);
x[i].addEventListener("mouseout",function(e){
this.style.boxShadow = "1px 1px 1px";
},false);
}
}
item_cards_event();
例
function item_cards_event(){
var x = document.getElementsByClassName('thumbnail_a');
for(var i = 0; i<x.length; i++){
x[i].addEventListener("mouseover",function(e){
this.style.boxShadow = "3px 3px 14px";
console.log(this.firstElementChild.alt);
console.log(this.firstElementChild.naturalWidth + 'x' + this.firstElementChild.naturalHeight);
},false);
x[i].addEventListener("mouseout",function(e){
this.style.boxShadow = "1px 1px 1px";
},false);
}
}
item_cards_event();
.naturalHeight
.naturalWidth
function item_cards_event(){
var x = document.getElementsByClassName('item_cards');
for(var i = 0; i<x.length; i++){
x[i].addEventListener("mouseover",function(e){
this.style.boxShadow = "3px 3px 14px";
console.log(this.firstElementChild.nextElementSibling.firstElementChild.naturalWidth + 'x' + this.firstElementChild.nextElementSibling.firstElementChild.naturalHeight);
},false);
x[i].addEventListener("mouseout",function(e){
this.style.boxShadow = "1px 1px 1px";
},false);
}
}
item_cards_event();
例
function item_cards_event(){
var x = document.getElementsByClassName('thumbnail_a');
for(var i = 0; i<x.length; i++){
x[i].addEventListener("mouseover",function(e){
this.style.boxShadow = "3px 3px 14px";
console.log(this.firstElementChild.alt);
console.log(this.firstElementChild.naturalWidth + 'x' + this.firstElementChild.naturalHeight);
},false);
x[i].addEventListener("mouseout",function(e){
this.style.boxShadow = "1px 1px 1px";
},false);
}
}
item_cards_event();
ラベル:
CSS,
Javascript
2016年2月2日火曜日
location プロパティ
location プロパティ
location.href
"http://www.asus.com/Motherboards/Z170-PRO/?SearchKey=Z170/"
location.origin
"http://www.asus.com"
location.protocol
"http:"
location.host
"www.asus.com"
location.hostname
"www.asus.com"
location.pathname
"/Motherboards/Z170-PRO/"
location.search
"?SearchKey=Z170/"
location.href
"http://www.asus.com/Motherboards/Z170-PRO/?SearchKey=Z170/"
location.origin
"http://www.asus.com"
location.protocol
"http:"
location.host
"www.asus.com"
location.hostname
"www.asus.com"
location.pathname
"/Motherboards/Z170-PRO/"
location.search
"?SearchKey=Z170/"
2016年1月27日水曜日
YouTube IFrame API ,再生リストの動作確認
YouTube IFrame API ,再生リストの動作確認、
以前に作成したプログラムは正常に停止しない、再び最初から
再生が始まります。そのための確認です。
今回のストップボイントは下記となります、各event.コード発生時に
実行します。
function stop(event){
if(event.target.getPlaylist()){
if(event.target.getVideoData().video_id == event.target.getPlaylist()[event.target.getPlaylist().length -1]) {
event.target.stopVideo();
}else{
event.target.playVideo();
}
}
}
<!DOCTYPE html>
<html>
<body>
<!-- 1. The <iframe> (and video player) will replace this <div> tag. -->
<div id="player"></div>
<script>
// YouTube Player API Reference for iframe Embeds
// https://developers.google.com/youtube/iframe_api_reference
// 2. This code loads the IFrame Player API code asynchronously.
var tag = document.createElement('script');
tag.src = "https://www.youtube.com/iframe_api";
var firstScriptTag = document.getElementsByTagName('script')[0];
firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
// 3. This function creates an <iframe> (and YouTube player)
// after the API code downloads.
var player;
function onYouTubeIframeAPIReady() {
player = new YT.Player('player', {
height: '0',
width: '0',
videoId: 'M7lc1UVf-VE',
events: {
'onReady': onPlayerReady,
'onStateChange': onPlayerStateChange,
'onError' : onPlayerError,
}
});
}
// 4. The API will call this function when the video player is ready.
function onPlayerReady(event) {
console.log(event.target.getPlayerState());
player.cuePlaylist({list:'PLoxAMAuDB1YbftJRZtIlec92SFNAPTnjW'});
event.target.playVideo();
}
function onPlayerStateChange(event) {
console.log('event.target.getPlayerState()' + event.target.getPlayerState());
console.log('event.data' + event.data);
console.log('player.getPlaylistId()' + event.target.getPlaylistId());
console.log('player.getPlaylist()' + event.target.getPlaylist());
console.log('player.getPlaylistIndex()' + event.target.getPlaylistIndex());
if(event.target.getPlayerState() == 5){
stop(event);
console.log('5---' + event.target.getPlayerState());
}
if(event.target.getPlayerState() == 4){
stop(event);
console.log('4---' + event.target.getPlayerState());
}
if(event.target.getPlayerState() == 3){
stop(event);
console.log('3---' + event.target.getPlayerState());
}
if(event.target.getPlayerState() == 2){
stop(event);
console.log('2---' + event.target.getPlayerState());
}
if(event.target.getPlayerState()== 1){
stop(event);
console.log('1---' + event.target.getPlayerState());
//event.target.nextVideo();
}
if(event.target.getPlayerState() == 0){
stop(event);
console.log('0--' + event.target.getPlayerState());
}
if(event.target.getPlayerState() == -1){
console.log('-1--' + event.target.getPlayerState());
}
}
function onPlayerError(event){
if(event.target.getPlaylist()){
if(event.target.getVideoData().video_id == event.target.getPlaylist()[event.target.getPlaylist().length -1]) {
event.target.stopVideo();
}else{
event.target.nextVideo();
}
}
}
function stop(event){
if(event.target.getPlaylist()){
if(event.target.getVideoData().video_id == event.target.getPlaylist()[event.target.getPlaylist().length -1]) {
event.target.stopVideo();
}else{
event.target.playVideo();
}
}
}
function stop_play() {
console.log(event.target.getPlayerState());
player.stopVideo();
}
//player.cuePlaylist({list:'PLoxAMAuDB1YbftJRZtIlec92SFNAPTnjW'});
</script>
</body>
</html>
以前に作成したプログラムは正常に停止しない、再び最初から
再生が始まります。そのための確認です。
今回のストップボイントは下記となります、各event.コード発生時に
実行します。
function stop(event){
if(event.target.getPlaylist()){
if(event.target.getVideoData().video_id == event.target.getPlaylist()[event.target.getPlaylist().length -1]) {
event.target.stopVideo();
}else{
event.target.playVideo();
}
}
}
<!DOCTYPE html>
<html>
<body>
<!-- 1. The <iframe> (and video player) will replace this <div> tag. -->
<div id="player"></div>
<script>
// YouTube Player API Reference for iframe Embeds
// https://developers.google.com/youtube/iframe_api_reference
// 2. This code loads the IFrame Player API code asynchronously.
var tag = document.createElement('script');
tag.src = "https://www.youtube.com/iframe_api";
var firstScriptTag = document.getElementsByTagName('script')[0];
firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
// 3. This function creates an <iframe> (and YouTube player)
// after the API code downloads.
var player;
function onYouTubeIframeAPIReady() {
player = new YT.Player('player', {
height: '0',
width: '0',
videoId: 'M7lc1UVf-VE',
events: {
'onReady': onPlayerReady,
'onStateChange': onPlayerStateChange,
'onError' : onPlayerError,
}
});
}
// 4. The API will call this function when the video player is ready.
function onPlayerReady(event) {
console.log(event.target.getPlayerState());
player.cuePlaylist({list:'PLoxAMAuDB1YbftJRZtIlec92SFNAPTnjW'});
event.target.playVideo();
}
function onPlayerStateChange(event) {
console.log('event.target.getPlayerState()' + event.target.getPlayerState());
console.log('event.data' + event.data);
console.log('player.getPlaylistId()' + event.target.getPlaylistId());
console.log('player.getPlaylist()' + event.target.getPlaylist());
console.log('player.getPlaylistIndex()' + event.target.getPlaylistIndex());
if(event.target.getPlayerState() == 5){
stop(event);
console.log('5---' + event.target.getPlayerState());
}
if(event.target.getPlayerState() == 4){
stop(event);
console.log('4---' + event.target.getPlayerState());
}
if(event.target.getPlayerState() == 3){
stop(event);
console.log('3---' + event.target.getPlayerState());
}
if(event.target.getPlayerState() == 2){
stop(event);
console.log('2---' + event.target.getPlayerState());
}
if(event.target.getPlayerState()== 1){
stop(event);
console.log('1---' + event.target.getPlayerState());
//event.target.nextVideo();
}
if(event.target.getPlayerState() == 0){
stop(event);
console.log('0--' + event.target.getPlayerState());
}
if(event.target.getPlayerState() == -1){
console.log('-1--' + event.target.getPlayerState());
}
}
function onPlayerError(event){
if(event.target.getPlaylist()){
if(event.target.getVideoData().video_id == event.target.getPlaylist()[event.target.getPlaylist().length -1]) {
event.target.stopVideo();
}else{
event.target.nextVideo();
}
}
}
function stop(event){
if(event.target.getPlaylist()){
if(event.target.getVideoData().video_id == event.target.getPlaylist()[event.target.getPlaylist().length -1]) {
event.target.stopVideo();
}else{
event.target.playVideo();
}
}
}
function stop_play() {
console.log(event.target.getPlayerState());
player.stopVideo();
}
//player.cuePlaylist({list:'PLoxAMAuDB1YbftJRZtIlec92SFNAPTnjW'});
</script>
</body>
</html>
2016年1月23日土曜日
addEventListener 一覧
分類 | イベントハンドラ | 発生状況 |
---|---|---|
onload | リソースのロードが完了したとき | |
onunload | アンロードされたとき (ロードする前) | |
readystatechange | documentのreadyState属性が変化したとき | |
フォーカス | onfocus | 要素が入力フォーカスを得たとき |
onblur | 要素が入力フォーカスを失ったとき | |
onchange | ユーザーが要素の値を変更し、要素が入力フォーカスを失ったとき (プログラムから変更した場合には、イベントは発生しない) | |
onselect | テキストが選択されたとき | |
oncontextmenu | マウスで右クリック、またはアプリケーションキーが押されるなどして、コンテキストメニューが表示されるとき | |
マウス | onclick | マウスでクリックされたとき |
ondblclick | マウスでダブルクリックされたとき | |
onmousedown | マウスボタンが押されたとき | |
onmouseup | マウスボタンが離されたとき | |
onmouseover | マウスが要素に乗ったとき | |
onmouseout | マウスが要素から離れたとき | |
onmousemove | マウスが要素の上を移動したとき | |
キー | onkeydown | ユーザーがキーを押したとき |
onkeypress | ユーザーがキーを押して離したとき | |
onkeyup | ユーザーがキーを離したとき | |
フォーム | onsubmit | フォームの送信が要求されたとき |
onreset | フォームのリセットが要求されたとき | |
onresize | ウィンドウのサイズが変更されたとき (Windowオブジェクトのみ) | |
onscroll | 要素のコンテンツがスクロールされたとき | |
onabort | 画像のロードが中断されたとき | |
onerror | 画像のロード中にエラーが発生したとき |
ラベル:
addEventListener,
Javascript
2016年1月20日水曜日
テキストボックスのオートコンプリートを無効
テキストボックスのオートコンプリートを無効
autocomplete="off"
<input type="text" name="input" autocomplete="off" />
autocomplete="off"
<input type="text" name="input" autocomplete="off" />
登録:
投稿 (Atom)