elements). AngularJS 1.2 introduces ng-repeat-start and ng-repeat-end as a better solution to this problem. Developers are encouraged to use this over custom comment directives when possible..
创建指令
首先让我们讨论下注册指令的API(API for registering directives). 和控制器一样,指令也是注册在模块之上的。为了注册一个指令,你需要使用 module.directive API。module.directive接受标准化的指令名称,后跟一个工厂函数。这个工厂函数应该返回一个具有不同选项的对象来告诉$compile指令在匹配时应该如何表现。
当$compile第一次匹配指令时,工厂函数仅被调用一次。你可以在这里指令任意的初始化工作。该(工厂)函数使用 $injector.invoke 来调用这使得它可以像控制器一样是可注入都。
我们将通过一些常见的指令示例,然后深入探讨不同的选项和编译过程。
Best Practice: In order to avoid collisions with some future standard, it's best to prefix your own directive names. For instance, if you created a directive, it would be problematic if HTML7 introduced the same element. A two or three letter prefix (e.g. btfCarousel) works well. Similarly, do not prefix your own directives with ng or they might conflict with directives included in a future version of AngularJS.
作为后续示例,我们将使用my前缀(例如 myCustomer)。
Template-expanding 指令
假设您有一大块代表客户信息的模板。这个模板在您的代码中重复多次。当你在一个地方改变它时,你必须在其他几个地方改变它。这是使用指令简化模板的好机会。
让我们创建一个指令,用一个静态模板简单地替换它的内容:https://jsfiddle.net/TommyLee...
注意我们在这个指令中有bindings。在$compile编译和链接
后,它将会尝试在元素的子元素上匹配指令。这意味着你可以组建指令的指令(嵌套指令)。我们将在后续看到如何编写 an example 。
在上面的例子中,我们列出了模板选项(template attribute of return object in factory function),但随着模板大小的增长,这将变得令人讨厌。
Best Practice: Unless your template is very small, it's typically better to break it apart into its own HTML file and load it with the templateUrl option.
如果你熟悉ngInclude,templateUrl就像它一样工作。下面是使用templateUrl代替的相同示例:https://plnkr.co/edit/idFOZ8Q...
templateUrl也可以是一个函数,它返回要加载和用于指令的HTML模板的URL。AngularJS将使用两个参数调用templateUrl函数:指令被调用的元素以及与该元素相关联的attr对象。
Note: You do not currently have the ability to access scope variables from the templateUrl function, since the template is requested before the scope is initialized 注:(要访问socpe上的值,应该在post-link阶段).
https://plnkr.co/edit/gaSYwnp...
restrict 选项通常设置为:
When should I use an attribute versus an element? Use an element when you are creating a component that is in control of the template.The common case for this is when you are creating a Domain-Specific Language for parts of your template. Use an attribute when you are decorating an existing element with new functionality.
用元素来使用myCustomer指令时明智的选择,因为你不用一些“customer”行为修饰一个元素,你定义一个元素核心行为作为一个costomer组建。
隔离指令的Scope
我们以上的myCustomer指令很好,但是它有一个致命缺陷。我们只有在一个给定的scope下使用。
在其目前的实现上,我们应该需要去创建一些不同点控制器用来重用这个指令。https://plnkr.co/edit/CKEgb1e...
这明显不是一个好的解决方案。
我们说项的是把指令内部的scope与外部scope(controller scope)分离,并且映射外部scope到指令内部scope。我们可以通过创建一个isolate scope来做。为此,我们可以使用指令的scope选项。
https://plnkr.co/edit/E6dTrgm... 看index.html文件,第一个元素绑定info属性值为naomi,它是我们已经暴露在我们的控制器上的scope。第二个绑定info为igor。
让我们仔细看看scope选项
//...
scope: { customerInfo: '=info' },
//...
除了可以将不同的数据绑定到指令中的作用域外,使用isolated scope还有其他作用。
我们可以通过添加另一个属性vojta来展示,到我们的scope并尝试从我们的指令模板中访问它:https://plnkr.co/edit/xLVqnzt...
请注意{{vojta.name}}和{{vojta.address}}为空,意味着它们未定义(undefined)。虽然我们在控制器中定义了vojta,但它在指令中不可用。
顾名思义,该指令的 isolate scope隔离了除显式添加到作用域的模型之外的所有内容:scope: {}散列对象. 这在构建可重用组件时很有用,因为它可以防止组件改变模型状态,除了显式传入。
Note: Normally, a scope prototypically inherits from its parent. An isolated scope does not. See the "Directive Definition Object - scope"section for more information about isolate scopes.
Best Practice: Use the scope option to create isolate scopes when making components that you want to reuse throughout your app.
创建一个操纵DOM的指令
在这个例子中,我们将建立一个显示当前时间的指令。每秒一次,它会更新DOM以反映当前时间。
想要修改DOM的指令通常使用link选项来注册DOM监听器以及更新DOM。它在模板被克隆之后执行,并且是放置指令逻辑的地方。
link接受一个带有一下签名的函数function link(scope, element, attrs, controller, transcludeFn) { ... }, 其中:
scope是一个Angularjs scope 对象
element 是一个此指令匹配的jqLite包装元素
attrs是一个具有标准化属性名称及其对应属性值的键值对的散列对象。
controller是指令所需的控制器实例或其自己的控制器(如果有的话)。确切的值取决于指令的 require属性。
transcludeFn是预先绑定到正确的包含范围的transclude链接函数。
For more details on the link option refer to the $compile API page.
在我们的link函数中,我们想每秒钟更新显示时间,或者一个用户改变了我们指令绑定的时间格式字符串。我们将会使用$interval服务定期调用处理程序。这比使用$ timeout更容易,但对于端到端测试也更好,我们希望确保在完成测试之前完成所有$timeout。如果指令被删除,我们也想删除$ interval,所以我们不会引入内存泄漏https://plnkr.co/edit/vIhhmNp...
这里有几件事需要注意。就像module.controller API一样,module.directive中的函数参数是依赖注入的。因此,我们可以在指令的链接函数中使用$ interval和dateFilter。
我们注册一个事件element.on('$ destroy',...)。什么引发了这个$ destroy事件?
AngularJS发布了一些特殊事件。当用AngularJS的编译器编译的DOM节点被销毁时,它会发起$ destroy事件。同样,当Angularjs scope被销毁,他会广播(broadcasts)一个$destory事件监听scopes。
通过监听此事件,可以删除可能导致内存泄漏的事件侦听器。注册到scope和element的监听事件在销毁DOM时会自动清理,但是如果您在服务上注册了侦听器,或者在未被删除的DOM节点上注册了侦听器,你必须自己清理它,否则你有冒险引入内存泄漏的风险。
Best Practice: Directives should clean up after themselves. You can use element.on('$destroy', ...) or scope.$on('$destroy', ...) to run a clean-up function when the directive is removed.
创建包装其他元素的指令
我们已经看到,您可以使用isolate scope将模型传递给指令,但是有时候想要能传入一整个模板而不是一个字符串或者对象。我们说我们想要创建一个“dialog box”组建。dialog box应该有能力包装任意的内容(any arbitrary content)。
为此,我们需要使用transclude选项。https://plnkr.co/edit/empMwVW...
transclude选项到底做了什么呢?transclude使指令的内容通过此选项拥有可访问外部指令的scope不是内部的scope。
为了说明了这一点,请看下面的例子。注意,我们在script.js中添加了一个link函数,将名称重新定义为Jeff。您认为{{name}}绑定将会得到什么结果?https://plnkr.co/edit/OEdkXY4...
照常,我们以为{{name}}应该是Jeff。但是,我们看见的是Tobias。
transclude选项改变了scope的嵌套方式。它使得一个transcluded指令的内容具有在指令之外的任何scope内容,而不是任何内部的scope。这样做,它可以让内容访问外部scope。
请注意,如果指令没有创建自己的独立作用域,那么scope.name ='Jeff'中的作用域将引用外部作用域,我们会在输出中看到Jeff。
这种行为对于封装某些内容的指令是有意义的,因为否则,您必须分别传入每个您想要使用的模型。如果你必须传入每一个你想要的model,那么你不能真正的使用任意的内容,对吗?
Best Practice: only use transclude: true when you want to create a directive that wraps arbitrary content.
接下来,我们要在此对话框中添加按钮,并允许使用该指令的用户将自己的行为绑定到该对话框。https://plnkr.co/edit/Bo5lona...
我们希望通过从指令的作用域调用它来运行我们传递的函数,但是它会在注册作用域的上下文中运行。
我们在之前已经看到在scope选项中如何使用 =attr,但是在上面的例子中,我们使用了&attr代替。 &绑定允许一个指令去触发一个原始范围内的表达式的评估,在一个特定时间点上。任何合法的表达式都是允许的,包括一个含有函数调用的表达式。如此,& 绑定是理想的将回调函数绑定到指令行为。
当用户点击dialog中的 x,指令的close函数被调用,多亏于ng-click。这个close调用在isolated scope之上,实际上会在原始scope的上下文中评估表达式 hideDialog(message),导致运行Controller中的hideDialog function。
通常期望通过一个表达式从isolate scope传入数据到父scope,这可以通过将局部变量名称和值的映射传递到表达式包装函数来完成。例如,hideDialkog函数接受一个message来显示当dialog被隐藏是。这被指令调用 close({message: 'closing for now'})指明。接着局部变量message将在on-close表达式内被访问(is available).
Best Practice: use &attr in the scope option when you want your directive to expose an API for binding to behaviors.
创建一个添加事件监听器的指令
以前,我们使用链接函数来创建操纵其DOM元素的指令。在这个例子的基础上,让我们制定一个对其元素事件做出反应的指令。
例如,如果我们想创建一个允许用户拖拽元素的指令呢?https://plnkr.co/edit/hcUyuBY...
创建一个通信的指令
你可以组建任何指令通过模板使用他们。
有时,你需要一个由指令组合构建的组件。
想象你想要有一个容器,其中容器的内容对应于哪个选项卡处于活动状态的选项卡。https://plnkr.co/edit/kqLjcwG...
myPane指令有require选项值为^^myTabs. 当指令使用此选项,&compile将抛出一个错误除非特定的controller被找到。 ^^前缀表示该指令在其父元素上搜索控制器。(^前缀将使指令在自身元素或她的父元素上寻找控制器;又没任何前缀,指令将值操作自身)
所以这个myTabs contoller从哪里来的?指令可以特定一个controllers通过使用 controller选项。如你所见,myTabs指令使用了此选项。就像ngController,此选项附加一个控制器到指令的模板上。
如果需要从模板中引用控制器或绑定到控制器的任何功能,则可以使用选项controllerAs将控制器的名称指定为别名。该指令需要定义要使用的此配置的范围。这在指令被用作组件的情况下特别有用。
回头看myPane的定义,注意到link函数的最后一个参数:tabCtrl。当指令需要控制器时,它将接收该控制器作为其link函数的第四个参数。利用这一点,myPane可以调用myTabs的addPane函数。
如果需要多个控制器,则指令的require选项可以采用数组参数。发送给链接函数的相应参数也将是一个数组。
angular.module('docsTabsExample', [])
.directive('myPane', function() {
return {
require: ['^^myTabs', 'ngModel'],
restrict: 'E',
transclude: true,
scope: {
title: '@'
},
link: function(scope, element, attrs, controllers) {
var tabsCtrl = controllers[0],
modelCtrl = controllers[1];
tabsCtrl.addPane(scope);
},
templateUrl: 'my-pane.html'
};
});
明的读者可能想知道链接和控制器之间的区别。基本的区别是控制器可以暴露一个API,并且链接函数可以使用require与控制器交互。
Best Practice: use controller when you want to expose an API to other directives. Otherwise use link.
总结
到此我们已经看了大多数指令的用法,每一个样例演示了一个创建你自己指令的好的起始点。
你可能深入感兴趣于编译过程的解释可以在这里获得compiler guide.
$compile API 有一个全面的指令清单选项以供参考。
最后
如有任何问题和建议欢迎发送至邮箱讨论: 翻译不易,若您觉得对您有帮助,欢迎打赏
微信:
支付宝:
你可能感兴趣的:(javascript,angularjs,directive)
ES6--《每日学习》
Oswaldhs
es6 学习 javascript
一、ES6相关介绍1.1、什么是ES61995年的美国,有一家名为netscape(网景)的公司打造了一款主要用于check验证的脚本语言,而恰在此时,Sun公司的java语言火的一塌糊涂,netscape公司为蹭其热度,便将该脚本语言命名为JavaScript。不料JavaScript居然被越来越多的人使用,后效仿大秦的货币统一政策将其提交给国际标准组织ECMA。该组织发布的标准被称做ECMAS
Vue.js项目构建
彭于晏“
vue.js
Vue.js是一个流行的JavaScript框架,用于构建用户界面。下面是使用Vue.js构建项目的详细方法:安装Vue.js:首先,你需要在项目中安装Vue.js。你可以通过在终端中运行以下命令来安装Vue.js:npminstallvue创建Vue实例:在项目的入口文件中,创建一个Vue实例。你可以使用以下代码创建一个简单的Vue实例:importVuefrom'vue';newVue({el
第 004 期 提高页面渲染速度的 3 个 CSS 技巧
前端GoGoGo7
提到提高页面渲染速度,我们第一想到的是优化JavaScript。其实通过优化CSS也能提高页面渲染速度。优化方案1.延时渲染屏幕外的内容-content-visibility:auto很长的页面会有大量的内容在屏幕外。如果只渲染屏幕内的内容,屏幕外的内容在出现时才渲染,能大大的节约渲染时间。CSSContainmentModuleLevel2模块新增了content-visibility属性。这个
js字符串方法速览---字符串的静态方法,实例方法和属性合集,各包含一个示例
I_am_shy
javascript 前端 开发语言
tips:本文仅作为查找和基本使用的展示,需要深入了解这些方法的使用请参考:String-JavaScript|MDN(mozilla.org)可以通过目录快速锁定需要查找的方法和查看它的使用目录tip:新建一个字符串字符串实例属性字符串静态方法String.fromCharCode(...nums)String.fromCodePoint(...nums)String.raw({raw:arr}
JavaScript防抖函数
喂!大掌柜
javascript 开发语言 ecmascript
在JavaScript中,你可以使用函数闭包来创建一个防抖函数。下面是一个简单的实现示例:functiondebounce(func,delay){lettimeoutId;returnfunction(){clearTimeout(timeoutId);timeoutId=setTimeout(func,delay);};}使用这个防抖函数时,你需要将需要防抖的函数和延迟时间作为参数传递给deb
停止在 TypeScript 中使用“any”类型
喂!大掌柜
typescript typescript javascript 前端 前端框架
有更好的TS类型和接口可用。为什么你不应该在TypeScript中使用“any”类型TypeScript是Web开发人员最常用的编程语言之一。它具有出色的语言功能,可让您轻松设计可扩展的应用程序。因此,开发人员倾向于为他们的项目选择TypeScript而不是JavaScript。但是,在使用TypeScript时,我们需要避免一些常见错误,以最大限度地发挥其功能。例如,过度使用any类型是我们经常
如何在小程序中实现页面之间的返回
那维莱特
小程序 apache
在小程序中实现页面之间的返回,通常有以下几种方法,这些方法各有特点,适用于不同的场景:1.使用wx.navigateBack方法描述:wx.navigateBack是微信小程序中用于关闭当前页面,返回上一页面或多级页面的API。使用方式:javascript复制代码wx.navigateBack({delta:1//表示返回上一级,如果delta大于1则表示返回多级});特点:可以根据delta的
javascript学习笔记--dom查询练习(二)
持续5年输出bug
通过具体的元素节点调用方法,返回当前节点的指定标签名后代节点getElementByTagName()1.属性,表示当前节点的所有子节点(会获取包括文本节点在内的所有子节点),在IE8及以下的浏览器中,不会将空白文本当成子节点:childNodes2.属性,是获取当前元素下的所有子元素这样就不会再包括空白文档:children3.属性表示当前节点的第一个子节点:firstChild4.属性表示当前
JavaScript 的变量、数据类型
wtbdwzbh
笔记 JavaScript javascript 笔记
一、变量变量:装数据的容器,数据可以修改。其本质是变量是内存中存放数据的空间。varage//声明一个变量ageage=10//给变量赋值varage=10//变量初始化,给变量同时声明和赋值更新变量一个变量被赋予新的值之后,原来的值就被覆盖掉了。同时声明多个变量只写一个var,要用英文逗号隔开。varname='张三',age=18,heigh=180;使用变量时必须声明,赋值。情况说明结果va
【面试题】JavaScript 中 try
2401_84438488
javascript 开发语言 ecmascript
地址:前端面试题库web前端面试题库VSjava后端面试题库大全作为一位Web前端工程师,JavaScript中的try...catch是我们常用的特性之一。try...catch可以捕获代码中的异常并防止应用程序崩溃。但是try...catch不仅仅是简单地捕获异常。本文我将分享10个有用的try...catch使用技巧,让你在处理异常时更加得心应手。1.捕获所有异常如果你想捕获代码中所有可能的
JS中【Data】详解
OEC小胖胖
JavaScript javascript 开发语言 ecmascript 前端 html
在JavaScript中,“Date”是一个内置对象,专门用于处理日期和时间。Date对象提供了多种方法,能够让你创建、操作和格式化日期和时间数据。下面我们将详细讲解Date对象的各个方面,包括它的创建、方法、使用场景和一些常见的坑。1.Date对象的创建1.1无参数构造constnow=newDate();如果不传递任何参数,Date对象将会默认创建一个表示当前日期和时间的对象。1.2通过时间戳
JS中【try…catch】讲解
OEC小胖胖
JavaScript javascript 前端 开发语言
try...catch语句是JavaScript中用于处理异常(错误)的一种机制。它允许你在代码中捕获并处理运行时错误,从而避免程序因未处理的错误而中断。try...catch语句的基本语法如下:try{//可能会抛出错误的代码}catch(error){//当错误发生时要执行的代码}finally{//无论是否发生错误,都会执行的代码(可选)}详细解释try块:try块中的代码是你认为可能会抛出
java json工具类_Java 的 JSON 开源类库之JackSon工具类--JSONUtils
奉义天涯
java json工具类
Java的JSON开源类库之JackSon工具类--JSONUtils,有需要的朋友可以参考下。JSON是JavaScriptObjectNotation的缩写,是一种轻量级的数据交换形式,是一种XML的替代方案,而且比XML更小,更快而且更易于解析。因为JSON描述对象的时候使用的是JavaScript语法,它是语言和平台独立的,并且这些年许多JSON的解析器和类库被开发出来。在这篇文章中,我们
Vue-cli创建单页面网页
caiyiii
安装npminstall-g@vue/cli创建项目vuecreate项目名选择预设环境使用键盘的上下键进行选择,enter键确定默认情况下是default(bableeslint)bable:下一代JavaScript编译器,将es6语法编译为es5语法eslint:规范代码行为,可组装的JavaScript和jsx检查工具可点击第二个,进行自主选择键盘上下键选择,空格选中创建的项目各个文件no
AUTOX.JS 新手入门
换个网名有点难
javascript 开发语言
工具介绍1.autoxjs1.1autojs介绍Auto.js是一个使用JavaScript编写Android自动化脚本的工具,由于原作者不再维护Auto.js项目,目前常见的两个分支:AutoX和Auto.jsPro。其中AutoX是开源的https://github.com/kkevsekk1/AutoX文档:http://doc.autoxjs.com/#/Auto.jsPro商业化版本,闭
JS中Object.prototype.toString方法解读
OEC小胖胖
JavaScript javascript 原型模式 开发语言
Object.prototype.toString是JavaScript中一个非常重要的方法,用于获取对象的类型信息。它的主要功能是返回一个表示对象类型的字符串。1.基本用法Object.prototype.toString是Object原型链上的一个方法,所有对象都可以访问它。默认情况下,它返回一个类似[objectType]的字符串,其中Type是对象的类型。例如:console.log(Ob
scrapy学习笔记0828-下
github_czy
scrapy 学习 笔记
1.爬取动态页面我们遇见的大多数网站不大可能会是单纯的静态网站,实际中更常见的是JavaScript通过HTTP请求跟网站动态交互获取数据(AJAX),然后使用数据更新HTML页面。爬取此类动态网页需要先执行页面中的JavaScript代码渲染页面,再进行爬取。在这里我们采用scrapy官方推荐的Splash渲染引擎,我们需要通过docker来安装splash并使其运行起来,这里就暂时不展开,安装
【js】什么是外围作用域
罗橙7号
javascript 开发语言 ecmascript
外围作用域(OuterScope)是指一个变量或函数定义时所在的上下文环境。在JavaScript中,作用域决定了如何查找变量,以及变量能被访问的范围。以下是关于外围作用域的几个关键点:概念:函数作用域:在JavaScript中,函数内部声明的变量在外部是不可见的,这形成了函数作用域。如果一个变量在当前函数作用域中没有找到,JavaScript解释器会继续在定义该函数的作用域中查找,这个作用域就是
【js】charCodeAt()用法
罗橙7号
javascript 前端 开发语言
在JavaScript中,charCodeAt()方法是字符串对象的一个方法,它返回在指定的位置的字符的Unicode编码。这个方法接受一个参数,即字符的位置(索引),索引从0开始。以下是如何使用charCodeAt()方法的示例:varstr="a";varcode=str.charCodeAt(0);//返回'a'的Unicode编码console.log(code);//输出97,因为'a'
【js】箭头函数和普通函数在this指向的区别
罗橙7号
javascript 前端 开发语言
在JavaScript中,箭头函数(ArrowFunctions)和普通函数(FunctionDeclarations/Expressions)在this的指向上有显著的不同:普通函数:函数定义时:this的值在函数被调用时才会确定,它取决于函数是如何被调用的。独立调用:如果函数是直接调用的(而不是作为对象的方法),在非严格模式下this指向全局对象(在浏览器中通常是window),在严格模式下t
javascript之三元运算符
冰暮流星
javascript笔记 javascript 开发语言 ecmascript
javascript三元运算符和c语言的很相似,语法格式都是条件?代码1:代码2等同于if(条件){代码1}else{代码2}假如要制作一个输入两个数据,比较大小并输出最大数的网页代码如下letnum1=+prompt('请输入第一个数:')letnum2=+prompt('请输入第二个数:')num1>num2?alert(`最大值是:${num1}`):alert(`最大值是:${num2}`
javaScript如何判断一个对象是否存在某个属性
道长道长IOT
javascript 开发语言
在JavaScript中检查一个对象是否包含某个属性可以通过几种不同的方法实现。以下是几种常用的方法:1.in操作符in操作符可以用来检测一个属性是否存在于对象中,包括原型链上的属性。constobj={foo:'bar'};if('foo'inobj){console.log('fooisintheobject');}2.hasOwnProperty()方法hasOwnProperty()方法只
关于严格模式的具体分析
6230_
前端基础 javascript 开发语言 ecmascript 前端 html 改行学it 学习方法
1、什么是ES5概念:ES5指的是:ECMAScript5,它是JavaScript语言的国际标准。ES5通过对现有JavaScript方法添加语句和原生ECMAScript对象做合并实现标准化还引入了一个语法的严格变种,被称为“严格模式”。2、如何开启严格模式写法:"usestrict"解释:只要将"usestrict"这个字符串放在代码的前方,后面的代码就会按照严格模式进行解释开启类型:局部开
JavaScript 深度剖析 - 函数式编程范式
时光海丶
大前端 javascript 函数式编程
函数式编程范式1.1函数式编程概念函数是一等公民高阶函数闭包1.2纯函数概念功能库lodash优劣纯函数的好处纯函数的副作用1.3柯里化(HaskellBrooksCurry)概念lodash中的柯里化函数总结1.4函数组合(compose)管道函数组合1.5Lodash中的fp模块1.6PointFree模式1.7函子Functor函子MayBe函子Either函子IO函子Task函子Point
JSON的概念及应用场景举例
可靠百灵鸟
json
JSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式,它采用易于人阅读和机器解析的纯文本形式来表示结构化的数据。JSON基于ECMAScript(即JavaScript)的一个子集,但其语法和数据结构独立于任何特定的编程语言,因此被广泛应用于各种编程环境和平台之间进行数据交换。JSON概念的关键特性包括:文本格式:JSON以纯文本的形式展现,由字符组成,可轻松通过
npm缓存深度解析:理解、使用与清除指南
2401_85762266
npm 缓存 前端
npm缓存深度解析:理解、使用与清除指南npm(NodePackageManager)是JavaScript编程语言的包管理器,广泛用于Node.js应用程序。它不仅帮助我们安装和管理项目依赖,还拥有一个强大的缓存机制来加速这一过程。本文将深入探讨npm缓存的概念、使用场景以及如何有效清除缓存,确保你的开发环境保持最佳状态。#️⃣npm缓存简介npm缓存是一个本地存储机制,用于保存已下载的包,以便
编程小白如何成为大神?大学新生的最佳入门大神级攻略
一禅(OneZen)
随笔 经验分享 其他 笔记 python java
编程语言选择1.选择一种编程语言入门:Python:Python是初学者的绝佳选择。它语法简单、易读易写、用途广泛,广泛应用于数据科学、机器学习、Web开发、自动化测试等领域。JavaScript:对于对Web开发感兴趣的学生,JavaScript是必学的。它在前端开发中占据主导地位,并且与HTML和CSS结合使用,构建动态网页。Java:Java是一种面向对象的编程语言,广泛应用于企业级应用和A
Qt 爬取网页信息
Qt历险记
Qt 高级开发工程师 qt 开发语言
QuestionQt爬取网页信息Answer学习如何使用Qt爬取网页信息的学习路线可以分为以下几个阶段:1.基础知识准备C++编程基础:Qt主要使用C++,因此需要有扎实的C++编程基础。网络编程基础:了解HTTP协议、TCP/IP等网络基础知识。HTML/CSS/JavaScript基础:了解网页的基本结构和内容。2.学习Qt框架Qt基础:学习Qt的基本概念,如信号与槽、事件处理、界面布局等。Q
如何上传NPM包:一步步指南
小于负无穷
javascript 开发语言 ecmascript 前端框架 前端 typescript
在JavaScript和Node.js开发中,NPM(NodePackageManager)是一个广泛使用的包管理工具。通过NPM,我们可以方便地管理项目中的依赖库,也可以将自己的代码打包发布给其他开发者使用。这篇文章将详细介绍如何将你自己的代码打包并上传到NPM仓库。1.准备工作在开始之前,你需要确保以下几点:安装了Node.js和NPM:可以通过在终端输入node-v和npm-v来检查是否安装
echarts瀑布图_一种基于阶梯瀑布图的数据计算方法与流程
孤独凤凰战士
echarts瀑布图
本发明涉及数据分析技术领域,具体地说是一种基于阶梯瀑布图的数据计算方法。背景技术:Echarts是一个纯Javascript的图表库,可以流畅的运行在PC和移动设备上,兼容当前绝大部分浏览器(IE8/9/10/11,Chrome,Firefox,Safari等),底层依赖轻量级的Canvas类库ZRender,提供直观,生动,可交互,可高度个性化定制的数据可视化图表。ECharts提供了常规的折线
SQL的各种连接查询
xieke90
UNION ALL UNION 外连接 内连接 JOIN
一、内连接
概念:内连接就是使用比较运算符根据每个表共有的列的值匹配两个表中的行。
内连接(join 或者inner join )
SQL语法:
select * fron
java编程思想--复用类
百合不是茶
java 继承 代理 组合 final类
复用类看着标题都不知道是什么,再加上java编程思想翻译的比价难懂,所以知道现在才看这本软件界的奇书
一:组合语法:就是将对象的引用放到新类中即可
代码:
package com.wj.reuse;
/**
*
* @author Administrator 组
[开源与生态系统]国产CPU的生态系统
comsci
cpu
计算机要从娃娃抓起...而孩子最喜欢玩游戏....
要让国产CPU在国内市场形成自己的生态系统和产业链,国家和企业就不能够忘记游戏这个非常关键的环节....
投入一些资金和资源,人力和政策,让游
JVM内存区域划分Eden Space、Survivor Space、Tenured Gen,Perm Gen解释
商人shang
jvm内存
jvm区域总体分两类,heap区和非heap区。heap区又分:Eden Space(伊甸园)、Survivor Space(幸存者区)、Tenured Gen(老年代-养老区)。 非heap区又分:Code Cache(代码缓存区)、Perm Gen(永久代)、Jvm Stack(java虚拟机栈)、Local Method Statck(本地方法栈)。
HotSpot虚拟机GC算法采用分代收
页面上调用 QQ
oloz
qq
<A href="tencent://message/?uin=707321921&Site=有事Q我&Menu=yes">
<img style="border:0px;" src=http://wpa.qq.com/pa?p=1:707321921:1></a>
一些问题
文强chu
问题
1.eclipse 导出 doc 出现“The Javadoc command does not exist.” javadoc command 选择 jdk/bin/javadoc.exe 2.tomcate 配置 web 项目 .....
SQL:3.mysql * 必须得放前面 否则 select&nbs
生活没有安全感
小桔子
生活 孤独 安全感
圈子好小,身边朋友没几个,交心的更是少之又少。在深圳,除了男朋友,没几个亲密的人。不知不觉男朋友成了唯一的依靠,毫不夸张的说,业余生活的全部。现在感情好,也很幸福的。但是说不准难免人心会变嘛,不发生什么大家都乐融融,发生什么很难处理。我想说如果不幸被分手(无论原因如何),生活难免变化很大,在深圳,我没交心的朋友。明
php 基础语法
aichenglong
php 基本语法
1 .1 php变量必须以$开头
<?php
$a=” b”;
echo
?>
1 .2 php基本数据库类型 Integer float/double Boolean string
1 .3 复合数据类型 数组array和对象 object
1 .4 特殊数据类型 null 资源类型(resource) $co
mybatis tools 配置详解
AILIKES
mybatis
MyBatis Generator中文文档
MyBatis Generator中文文档地址:
http://generator.sturgeon.mopaas.com/
该中文文档由于尽可能和原文内容一致,所以有些地方如果不熟悉,看中文版的文档的也会有一定的障碍,所以本章根据该中文文档以及实际应用,使用通俗的语言来讲解详细的配置。
本文使用Markdown进行编辑,但是博客显示效
继承与多态的探讨
百合不是茶
JAVA面向对象 继承 对象
继承 extends 多态
继承是面向对象最经常使用的特征之一:继承语法是通过继承发、基类的域和方法 //继承就是从现有的类中生成一个新的类,这个新类拥有现有类的所有extends是使用继承的关键字:
在A类中定义属性和方法;
class A{
//定义属性
int age;
//定义方法
public void go
JS的undefined与null的实例
bijian1013
JavaScript JavaScript
<form name="theform" id="theform">
</form>
<script language="javascript">
var a
alert(typeof(b)); //这里提示undefined
if(theform.datas
TDD实践(一)
bijian1013
java 敏捷 TDD
一.TDD概述
TDD:测试驱动开发,它的基本思想就是在开发功能代码之前,先编写测试代码。也就是说在明确要开发某个功能后,首先思考如何对这个功能进行测试,并完成测试代码的编写,然后编写相关的代码满足这些测试用例。然后循环进行添加其他功能,直到完全部功能的开发。
[Maven学习笔记十]Maven Profile与资源文件过滤器
bit1129
maven
什么是Maven Profile
Maven Profile的含义是针对编译打包环境和编译打包目的配置定制,可以在不同的环境上选择相应的配置,例如DB信息,可以根据是为开发环境编译打包,还是为生产环境编译打包,动态的选择正确的DB配置信息
Profile的激活机制
1.Profile可以手工激活,比如在Intellij Idea的Maven Project视图中可以选择一个P
【Hive八】Hive用户自定义生成表函数(UDTF)
bit1129
hive
1. 什么是UDTF
UDTF,是User Defined Table-Generating Functions,一眼看上去,貌似是用户自定义生成表函数,这个生成表不应该理解为生成了一个HQL Table, 貌似更应该理解为生成了类似关系表的二维行数据集
2. 如何实现UDTF
继承org.apache.hadoop.hive.ql.udf.generic
tfs restful api 加auth 2.0认计
ronin47
目前思考如何给tfs的ngx-tfs api增加安全性。有如下两点:
一是基于客户端的ip设置。这个比较容易实现。
二是基于OAuth2.0认证,这个需要lua,实现起来相对于一来说,有些难度。
现在重点介绍第二种方法实现思路。
前言:我们使用Nginx的Lua中间件建立了OAuth2认证和授权层。如果你也有此打算,阅读下面的文档,实现自动化并获得收益。SeatGe
jdk环境变量配置
byalias
java jdk
进行java开发,首先要安装jdk,安装了jdk后还要进行环境变量配置:
1、下载jdk(http://java.sun.com/javase/downloads/index.jsp),我下载的版本是:jdk-7u79-windows-x64.exe
2、安装jdk-7u79-windows-x64.exe
3、配置环境变量:右击"计算机"-->&quo
《代码大全》表驱动法-Table Driven Approach-2
bylijinnan
java
package com.ljn.base;
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Collections;
import java.uti
SQL 数值四舍五入 小数点后保留2位
chicony
四舍五入
1.round() 函数是四舍五入用,第一个参数是我们要被操作的数据,第二个参数是设置我们四舍五入之后小数点后显示几位。
2.numeric 函数的2个参数,第一个表示数据长度,第二个参数表示小数点后位数。
例如:
select cast(round(12.5,2) as numeric(5,2))  
c++运算符重载
CrazyMizzz
C++
一、加+,减-,乘*,除/ 的运算符重载
Rational operator*(const Rational &x) const{
return Rational(x.a * this->a);
}
在这里只写乘法的,加减除的写法类似
二、<<输出,>>输入的运算符重载
&nb
hive DDL语法汇总
daizj
hive 修改列 DDL 修改表
hive DDL语法汇总
1、对表重命名
hive> ALTER TABLE table_name RENAME TO new_table_name;
2、修改表备注
hive> ALTER TABLE table_name SET TBLPROPERTIES ('comment' = new_comm
jbox使用说明
dcj3sjt126com
Web
参考网址:http://www.kudystudio.com/jbox/jbox-demo.html jBox v2.3 beta [
点击下载]
技术交流QQGroup:172543951 100521167
[2011-11-11] jBox v2.3 正式版
- [调整&修复] IE6下有iframe或页面有active、applet控件
UISegmentedControl 开发笔记
dcj3sjt126com
// typedef NS_ENUM(NSInteger, UISegmentedControlStyle) {
// UISegmentedControlStylePlain, // large plain
&
Slick生成表映射文件
ekian
scala
Scala添加SLICK进行数据库操作,需在sbt文件上添加slick-codegen包
"com.typesafe.slick" %% "slick-codegen" % slickVersion
因为我是连接SQL Server数据库,还需添加slick-extensions,jtds包
"com.typesa
ES-TEST
gengzg
test
package com.MarkNum;
import java.io.IOException;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.ServletException;
import javax.servlet.annotation
为何外键不再推荐使用
hugh.wang
mysql DB
表的关联,是一种逻辑关系,并不需要进行物理上的“硬关联”,而且你所期望的关联,其实只是其数据上存在一定的联系而已,而这种联系实际上是在设计之初就定义好的固有逻辑。
在业务代码中实现的时候,只要按照设计之初的这种固有关联逻辑来处理数据即可,并不需要在数据库层面进行“硬关联”,因为在数据库层面通过使用外键的方式进行“硬关联”,会带来很多额外的资源消耗来进行一致性和完整性校验,即使很多时候我们并不
领域驱动设计
julyflame
VO DAO 设计模式 DTO po
概念:
VO(View Object):视图对象,用于展示层,它的作用是把某个指定页面(或组件)的所有数据封装起来。
DTO(Data Transfer Object):数据传输对象,这个概念来源于J2EE的设计模式,原来的目的是为了EJB的分布式应用提供粗粒度的数据实体,以减少分布式调用的次数,从而提高分布式调用的性能和降低网络负载,但在这里,我泛指用于展示层与服务层之间的数据传输对
单例设计模式
hm4123660
java Singleton 单例设计模式 懒汉式 饿汉式
单例模式是一种常用的软件设计模式。在它的核心结构中只包含一个被称为单例类的特殊类。通过单例模式可以保证系统中一个类只有一个实例而且该实例易于外界访问,从而方便对实例个数的控制并节约系统源。如果希望在系统中某个类的对象只能存在一个,单例模式是最好的解决方案。
&nb
logback
zhb8015
log logback
一、logback的介绍
Logback是由log4j创始人设计的又一个开源日志组件。logback当前分成三个模块:logback-core,logback- classic和logback-access。logback-core是其它两个模块的基础模块。logback-classic是log4j的一个 改良版本。此外logback-class
整合Kafka到Spark Streaming——代码示例和挑战
Stark_Summer
spark storm zookeeper PARALLELISM processing
作者Michael G. Noll是瑞士的一位工程师和研究员,效力于Verisign,是Verisign实验室的大规模数据分析基础设施(基础Hadoop)的技术主管。本文,Michael详细的演示了如何将Kafka整合到Spark Streaming中。 期间, Michael还提到了将Kafka整合到 Spark Streaming中的一些现状,非常值得阅读,虽然有一些信息在Spark 1.2版
spring-master-slave-commondao
王新春
DAO spring dataSource slave master
互联网的web项目,都有个特点:请求的并发量高,其中请求最耗时的db操作,又是系统优化的重中之重。
为此,往往搭建 db的 一主多从库的 数据库架构。作为web的DAO层,要保证针对主库进行写操作,对多个从库进行读操作。当然在一些请求中,为了避免主从复制的延迟导致的数据不一致性,部分的读操作也要到主库上。(这种需求一般通过业务垂直分开,比如下单业务的代码所部署的机器,读去应该也要从主库读取数