2019.6.22 Web全栈开发 学习笔记(九)

JavaScript Day 2

上课日期:2019年8月2日

课程内容

一、JavaScript代码写在< body>中和写在< head>中
JavaScript代码一般都写在< body>中,如果执意要写在< head>中,由于< head>中没有进行初始化,则需要用到window.onload事件,即加载完成事件,意味着浏览器中的DOM元素已经渲染完成。
即,当我们定义一个按钮之后
< button id="btn" style="width: 100px; border: 1px solid red;">按钮< /button>

<head lang="en">
<script>
        window.onload=function (){
         var btn=document.getElementById("btn");
         console.log(btn);
         }
    </script>
</head>

以及

<body>
<script>
var btn = document.getElementById("btn");
    console.log(btn);
    </script>
</body>

这两段代码都能获取到该id为btn的按钮

二、JavaScript中获取或设置元素属性
设置一个按钮

<button id="btn" class="btnlist" style="width: 100px; border: 1px solid red;">按钮</button>

使用类似

var btn = document.getElementById("btn");
console.log(btn.className);
    btn.className = "btnlist btnadd";

这样的代码即可将btn按钮在原本的类btnlist的基础上再添加一个btnadd类。
(注:在添加新的类的时候,一定要注意先写其原本的类)

三、JavaScript中操作元素的文本值
操作当前元素文本值有两种方法,即btn.innerHTML 或者btn.innerText
例如,我要将之前所定义的按钮中的文字修改,可用

var btn = document.getElementById("btn");
btn.innerHTML="点击我" 
    btn.innerText="点击我"

来实现,这两种方法都可以将按钮里面的文字改为“点击我”。
区别:

btn.innerHTML="<span>我是按钮</span>";
    btn.innerText="<span>我是按钮</span>";

innerHTML方法如果所给的值里面包含标签,例如< span>标签,它可以对该标签进行解析,而innerText方法则不会解析标签,而是将你所给的值直接显示出来。

四、JavaScript中对样式的相关操作
JavaScript可以对行内样式进行操作,但不能直接操作内嵌或者外部样式
例如:

var btn = document.getElementById("btn");
btn.style.backgroundColor="red";
console.log(btn.style.width);

可以将按钮的背景颜色改成红色,也可以输出按钮的宽度值

如果要对内嵌样式或者外部样式进行操作,则需要用到window.getComputedStyle()方法

console.log(window.getComputedStyle(btn).height);

这样就可以输出写在内嵌样式中的高度值了。

五、JavaScript的其他获取属性方式
使用getAttribute方法可以获取到对象的属性
例如:

console.log(btn.getAttribute("id"));
    console.log(btn.getAttribute("class"));
    console.log(btn.getAttribute("style"));

就可以获取到按钮的id值,class值以及style样式的值
同时,getAttribute也可以获取到自定义属性,而自定义属性是使用setAttribute定义的

    btn.setAttribute("data-src", "./img/1.jpg");
    console.log(btn.getAttribute("data-src"));

六、JavaScript中数据类型的强制转换
由于JavaScript是弱类型语言,所以在定义和使用变量时经常会出现数据类型上的问题,所以讲变量的数据类型进行强制转换很重要。
数据类型强制转换的方法有parseFloat,parseInt等
例如:

var b = "1.23";
    console.log(parseFloat(b));
    console.log(parseInt(b));

第一次输出的是强制转换成浮点型的数据,为1.23
第二次输出的则是强制转换为整型的数据,即为1

整理自尚硅谷视频教程springboot高级篇,并增加部分springboot2.x的内容 一、Spring Boot与缓存 一、JSR107 Java Caching定义了5个核心接口,分别是CachingProvider, CacheManager, Cache, Entry 和 Expiry。 • CachingProvider定义了创建、配置、获取、管理和控制多个CacheManager。一个应用可 以在运行 期访问多个CachingProvider。 • CacheManager定义了创建、配置、获取、管理和控制多个唯一命名 的Cache,这些Cache 存在于CacheManager的上下文中。一个CacheManager仅被一个 CachingProvider所拥有。 • Cache是一个类似Map的数据结构并临时存储以Key为索引的值。一个 Cache仅被一个 CacheManager所拥有。 • Entry是一个存储在Cache中的key-value对。 • Expiry 每一 个存储在Cache中的条目有一个定义的有效期。一旦超过这个时间,条目为过期 的状态。一旦过期,条 目将不可访问、更新和删除。缓存有效期可以通过ExpiryPolicy设置。 二、Spring缓存抽象 Spring从3.1开始定义了org.springframework.cache.Cache 和 org.springframework.cache.CacheManager接口来统一不同的缓存技术; 并支持使用JCache(JSR- 107)注解简化我们开发; • Cache接口为缓存的组件规范定义,包含缓存的各种操作集合; • Cache接 口下Spring提供了各种xxxCache的实现;如RedisCache,EhCacheCache , ConcurrentMapCache 等; • 每次调用需要缓存功能的方法时,Spring会检查检查指定参数的指定的目标方法是否 已经被调用 过;如果有就直接从缓存中获取方法调用后的结果,如果没有就调用方法 并缓存结果后返回给用户。下 次调用直接从缓存中获取。 • 使用Spring缓存抽象时我们需要关注以下两点; 1、确定方法需要被缓存 以及他们的缓存策略 2、从缓存中读取之前缓存存储的数据 Cache 缓存接口,定义缓存操作。实现有:RedisCache、EhCacheCache、 ConcurrentMapCache等 CacheManager 缓存管理器,管理各种缓存(Cache)组件 @Cacheable 主要针对方法配置,能够根据方法的请求参数对其结果进行缓存 @CacheEvict 清空缓存 @CachePut 保证方法被调用,又希望结果被缓存。 @EnableCaching 开启基于注解的缓存 keyGenerator 缓存数据时key生成策略 serialize 缓存数据时value序列化策略 @CacheConfig 抽取缓存的公共配置 三、几个重要概念&缓存注解 1、常用注解 2、常用参数 名字 位置 描述 示例 methodName root object 当前被调用的方法名 #root.methodName method root object 当前被调用的方法 #root.method.name target root object 当前被调用的目标对象 #root.target targetClass root object 当前被调用的目标对象类 #root.targetClass args root object 当前被调用的方法的参数列表 #root.args[0] 3、常用参数SPEL说明 名字 位置 描述 示例 caches root object 当前方法调用使用的缓存列表(如 @Cacheable(value= {"cache1","cache2"}) ), 则有两 个cache #root.caches[0].name argument name evaluation context 方法参数的名字. 可以直接 #参数 名 ,也可以使用 #p0或#a0 的形 式,0代表参数的索引; #iban 、 #a0 、 #p0 result evaluation context 方法执行后的返回值(仅当方法执 行之后的判断有效,如‘unless’ , ’cache put’的表达式 ’cache evict’的表达式 beforeInvocation=false ) #result 四、代码中使用缓存 1、搭建基本环境 1、导入数据库文件 创建出department和employee表 2、创建javaBean封装数据 3、整合MyBatis操作数据库 1.配置数据源信息 2.使用注解版的MyBatis; 1)、@MapperScan指定需要扫描的mapper接口所在的包
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值