浅谈nodejs文件操作中的相对路径问题

JavaScript021

浅谈nodejs文件操作中的相对路径问题,第1张

查看以下场景:

在 /js 目录下执行 node foo/index.js ,会出现文件找不到的情况,原因: /js/foo/index.js 文件中读文件是写的相对路径也即: ./a.txt ,而这个相对路径实际上是相对于执行 node 命令所处的路径,也即以上的执行node时,进行文件操作时查找的路径是: js/a.txt 显然 /js 目录下没有该文件,也就查找失败。

再看一种场景

在 /js 目录下执行 node other.js 命令,执行结果为:

原因和之前的一样,虽然在 js 下执行该命令,但是在该文件中还是在引入并执行 index.js 文件,由于 node 命令执行的目录是: /js 目录,所以在文件操作的时候,查找的文件目录是: /js/a.txt ,显然又是找不到的结果

所以在文件操作中,相对路径是不可靠的,为了解决这个问题,则需要将相对路径改为绝对路径。但是如果仅仅是将文件操作的路径改为 C:\node\js\foo\a.txt 路径,则当交付项目的时候,还需要将该路径改为当前项目所处计算机的绝对路径,显然这是不可行的,因此 __dirname 开始发挥作用。

而什么 __dirname 是什么呢?

在每个模块中,除了 require 、 exports 等模块相关API之外,还有两个特殊的成员

由于 __dirname 不受node命令所属路径影响,同时又可以动态的获取当前文件的绝对路径,因此可以是个不错的选择,将 /foo/index.js 修改:

模块中 require 中所写的路径跟文件操作的路径是没有关系的,其路径是相对于文件模块的,也即相对于当前文件模块(文件)所处目录的相对路径。

此时查找 ./foo/index.js 就是相对于 /js 目录

1、直接设置style对象(内联样式)

使用JavaScript设置元素样式的最简单方法是使用style属性。在我们通过JavaScript访问的每个HTML元素时都有一个 style对象。此对象允许我们指定CSS属性并设置其值。例如,这是设置id 值为demo的HTML元素的字体颜色、背景颜色、的样式:var myElement = document.querySelector("#demo")

// 把颜色设置成紫色

elem.style.color = 'purple'

// 将背景颜色设置为浅灰色

elem.style.backgroundColor = '#e5e5e5'

// 将高度设置为150 px

elem.style.height = '150px'

注:JavaScript使用驼峰原则(例:backgroundColor)而不是短划线(background-color)表示属性名称

该style属性在元素上添加样式内联:

Hello, world!

但是,这可能会使我们的标记变得非常混乱。浏览器渲染的性能也较差。

2、设置style属性--添加全局样式

另一种方法是将里带有CSS属性的元素注入DOM。将在设置应用于一组元素而不仅仅是一个元素的样式时,这非常有用。

首先,我们将创建一个样式元素。var style = document.createElement('style')

接下来,我们将通过innerHTML来给

style.innerHTML =

'.some-element {' +

'color: purple' +

'background-color: #e5e5e5' +

'height: 150px' +

'}'

最后,我们将把样式注入DOM。为此,我们将获取script我们在DOM中找到的第一个标记,并用它insertBefore()来添加我们的style标记。// 创建我们的样式表

var style = document.createElement('style')

style.innerHTML =

'.some-element {' +

'color: purple' +

'background-color: #e5e5e5' +

'height: 150px' +

'}'

// 获取第一个脚本标记

var ref = document.querySelector('script')

// 在第一个脚本标签之前插入新样式

ref.parentNode.insertBefore(style, ref)

3、使用JavaScript添加和删除类:add()和remove()

这种方法涉及添加和删除类值,这反过来又会改变应用的样式规则。例如,假设我们有一个样式规则,如下所示:.disableMenu {

display: none

}

在HTML中,您有一个id为 dropDown的菜单:

123456

现在,如果我们想将.disableMenu 样式规则应用于此元素中,我们需要做的就是将disableMenu作为类值添加到dropDown元素:

OneTwoThreeFourFiveSix

要使用JavaScript完成相同的结果,我们将使用classList API。此API使得从HTML元素添加或删除类值变得非常简单。

要将disableMenu类名添加到我们的dropDown元素,请在HTML元素的classList属性上使用add()方法:var theDropDown = document.querySelector("#dropDown")

theDropDown.classList.add("disableMenu")

要删除disableMenu类名,我们可以调用classList API的remove()方法:var theDropDown = document.querySelector("#dropDown")

theDropDown.classList.remove("disableMenu")

只是个最基础的想法了。具体的实践稍微复杂一些:

1 如果script是用src引入的,还要用xhr或者json方式来获得text,可能还需要搭个后台代理。

2 如果function是在命名空间的,可以直接递归for in命名空间去挖里面的public函数出来。

3 private的函数我看就算了,私有函数应该对自己负责,我们没有必要非去整人家的私货。

<HTML>

<BODY>

<SCRIPT LANGUAGE="JavaScript">

<!--

function a(x,y,z){return b(x,y)*c(z)}

function b(x,y){return c(x)*c(y)}

function c(x){return x+x}

setTimeout("alert(a(1,2,3))",0)

//-->

</SCRIPT>

<SCRIPT LANGUAGE="JavaScript">

<!--

(function (){

window._log=[]

function obj2str(o){

var r = []

if(typeof o =="string") return "/""+o.replace(/([/'/"//])/g,"//$1").replace(/(/n)/g,"//n").replace(/(/r)/g,"//r").replace(/(/t)/g,"//t")+"/""

if(typeof o =="undefined") return "undefined"

if(typeof o == "object"){

if(o===null) return "null"

else if(!o.length){

for(var i in o)

r.push(i+":"+obj2str(o[i]))

r="{"+r.join()+"}"

}else{

for(var i =0i<o.lengthi++)

r.push(obj2str(o[i]))

r="["+r.join()+"]"

}

return r

}

return o.toString()

}