写给后端工程师的前端课程(蛋人网)

3.JavaScript入门
4.jQuery和Ajax学习

3.JavaScript入门
两个方面的内容:javascript入门和javascript的DOM操作
基本数据类型:
Number
Boolean
String
Array
Object(在ruby中是hash数据类型)

//对象的定义方法
var user = {
  name: "jayzen",
  age: 18
}
//对象值的获取方式
console.log(user.name); 
console.log(user['age']);

变量声明

//使用var声明变量
var a;

//也可以不采用var声明变量,但是前提这个变量是引用了外部作用域(也是全局作用域)的变量

//用例子进行说明
var x=1;

function counter(seq){
  var x = seq * seq;  #定义一个局部变量x,不会改变上面变量x的值
  return x;
}
function counter2(seq){
  x = seq * seq; #x是最上面的var x的值,这条语句会改变最上面全局变量x的值
  return x;
}

Function

//一般的定义方式
function hello(name){
  console.log(name);
}
hello('343'); //调用方式,如果没有带参数,也是需要()这个括号

//定义匿名函数
var showAlert = function(name){
  console.log(name);
}
showAlert('343');

//闭包(保留了作用域的变量值)
var showAlert = function(name){
  name = name + "" + "world";

  return function(index){
    console.log(index + "" + name);  //能获取上层作用域的变量
  }
}

var error = showAlert('hello');
error(1);

//闭包的另外一种表现形式,好处是避免变量之间互相影响
(function(){
  var a = 1;
  console.log(a);
})();  //相当于执行了一个匿名函数 => 匿名函数.()

function返回值

//function的返回值必须使用return关键词,不像ruby中可以使用代码中的最后一句话作为返回值
function counter(x){
  return x**x
}
counter(2);

什么是false

null
undefined
false

变量命名

//驼峰式命名,第一个词全部小写,第二个词首字母大写,其他小写
var helloWorld = "hello world";
function showAlert(){.....};

条件控制

if (true){
...
}else{
...
}

循环和遍历

//初始值,变化值,以及判断条件
for(var x=0; x++; x<10){
...
}

条件控制

//使用while
var x=10;
while(x>=0){
  console.log(x);
  x--;
}

//使用switch
switch(a){
  case 1:
  ...
    break;
  default:
  ...
}

javascript的DOM操作
DOM操作

//dom节点查询
//dom节点标签属性增加、删除、修改
//dom节点增加、删除、修改
//浏览器事件的操作

document.getElementByTags('a');
document.getElementByClassName('row');

Event事件

click
mouseover
mousemove
focus
blur
touch

4.jQuery和Ajax学习
jquery是对js的DOM操作的一些封装,同时对不同浏览器的兼容性做了处理。jquery是基于DOM实现的。
jquery的dom节点选择

//$符号是jquery提供的全局变量
$('p');  //获取所有的p标签
$('.row'); //获取所有class为row的节点
$('#wrapper');  //获得id为wrapper的节点
$('.row:last');//获得class为row的节点中的最后一个节点
$('input[name="username"]'); //获得标签为input,同时name为username的节点

//dom节点的维护
$('p').hide();
$('p').show();
$('p').remove();

//jquery对象!=DOM对象
var wrapper = $('#wrapper');
var wrapper2 = document.getElementById('wrapper');
wrapper == wrapper2 //false
wrapper.get(0) == wrapper2 //true, wrapper是一个数组

//DOM属性操作
$('#wrapper').addClass('theme');
$('#wrapper').removeClass('theme');
$('#wrapper').attr('class');//返回当前给定属性节点的值
$('#wrapper').attr('custom-attr', 'attr_value');//当前属性的值设置为value
..
$('a').attr('href');

//jQuery的事件绑定
$('#wrapper').click(function(){
  console.log("wrapper clicked");
})
//same as above
$('#wrapper').on('click', function(){
  console.log("wrapper clicked");
})
//自定义事件
$('#wrapper').on('custom-event-name', function(e){
  console.log("custom event triggered");
})
$('#wrapper').trigger('custom-event-name');

//自定义事件-动态元素的绑定,针对本来页面上不存在的元素
$(document).on('click', '#wrapper', function(e){
  console.log("custom event triggered")
})

//animate动画
$('#wrapper').animate({
  height: 300,
  opacity: 0.2
})

ajax介绍
asynchronous javascript and xmlhttprequest

//直接使用jquery的ajax
$.ajax({
  url: '/sessions',
  type: 'post',
  data: {username: 'username', password: 'password'},
  dataType: 'json',
  beforeSend: function(e){
  ...
  },
  success: function(data){
  ...
  },
...
})

JSON
javascript object

{
  total_entries: 30
  rows: [
   {id: 1, username: "343"},
   ...
  ]
}

你可能感兴趣的:(写给后端工程师的前端课程(蛋人网))