`
BabyDuncan
  • 浏览: 585576 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

javascript解决pdf阅读器的书签

阅读更多
最近有大量的资料需要阅读,常常用到Adobe Reader8.0阅览器。不过最让人头疼的就是这个阅览器没有添加书签的功能。如果遇到上百页的文本,自己下次阅读的时候还需要自己再重复寻找上次的阅读终点,那么有没有在Adobe Reader8.0阅览器中添加书签的方法呢?最近通过摸索和网络求助,找到了一个简单快捷的方法在Adobe Reader8.0阅览器中添加书签。

具体步骤如下:

       第一步,下载一个“PDF支持书签的修改程序源文件”。地址为“http://download.csdn.net/source/362724”(如果你能链接则将全部复制到地址栏回车即可)。

       第二步,将下载的文件重命名为“bookmark_page.js”.

       第三步,将bookmark_page.js文件复制到“计算机/C:/Program Files/Adobe/Reader8.0/Reader/Javascripts/”(我的计算机是Vista系统,如果是XP系统的话将文件复制到 C:/Program Files/Adobe/Reader8.0/Reader/Javascripts/即可)。

       第四步,重新启动Reader8.0,你会在视图选项的下拉菜单中看到有设置本页为书签、转到指定书签、删除一个书签和删除所以书签选项,这样你就可以添加书签了!



注:如果下载不了,可以用下载代码复制另存为bookmark_page.js即可.

// bookmark_page.js, ver. 1.0
// visit: www.pdfhacks.com/bookmark_page/
// edit:cjs 2008-02-17
// 1 修改为中文标签
// 2 设置书签时可以自动获取当前的书名
// 3 自动获取当前所在的页码与总页数,方便查阅
// 4 实现更多功能可以参看Adobe Reader的SDK


// use this delimiter for serializing our array
var bp_delim= '%#%#';

function SaveData( data ) {
  // data is an array of arrays that needs
  // to be serialized and stored into a persistent
  // global string
  var ds= '';
  for( ii= 0; ii< data.length; ++ii ) {
    for( jj= 0; jj< 3; ++jj ) {
      if( ii!= 0 || jj!= 0 )
        ds+= bp_delim;
      ds+= data[ii][jj];
    }
  }
  global.pdf_hacks_js_bookmarks= ds;
  global.setPersistent( "pdf_hacks_js_bookmarks", true );
}

function GetData() {
  // reverse of SaveData; return an array of arrays
  if( global.pdf_hacks_js_bookmarks== null ) {
    return new Array(0);
  }

  var flat= global.pdf_hacks_js_bookmarks.split( bp_delim );
  var data= new Array();
  for( ii= 0; ii< flat.length; ) {
    var record= new Array();
    for( jj= 0; jj< 3 && ii< flat.length; ++ii, ++jj ) {
      record.push( flat[ii] );
    }
    if( record.length== 3 ) {
      data.push( record );
    }
  }
  return data;
}

//Get Current Date
function DateNow(){
   var d, s ;
   d = new Date();
   s = d.getFullYear()+"/";
   s += (d.getMonth() + 1) + "/";
   s += d.getDate() ;
   /*
   s += d.getHours() + ":";
   s += d.getMinutes() + ":";
   s += d.getSeconds() ;
   */
   return(s);
}


function AddBookmark() {
  // query the user for a name, and then combine it with
  // the current PDF page to create a record; store this record
  var thisfilename=this.documentFileName;
  thisfilename=thisfilename.substr(0,thisfilename.lastIndexOf("."));
  var numPlugInss=this.pageNum+1;
  var currentdate=DateNow();
  var label=
    app.response( "书签名称,可以修改以便于记忆:",
                  "书签名称",
                  "《"+thisfilename+"》第 "+numPlugInss+" 页/共 "+this.numPages+" 页  "+currentdate,
                  false );
  if( label!= null ) {
    var record= new Array(3);
    record[0]= label;
    record[1]= this.path;
    record[2]= this.pageNum;
    data= GetData();
    data.push( record );
    SaveData( data );
  }
}

function ShowBookmarks() {
  // show a pop-up menu; this seems to only work when
  // a PDF is alreay in the viewer;
  var data= GetData();
  var items= '';
  for( ii= 0; ii< data.length; ++ii ) {
    if( ii!= 0 )
      items+= ', ';
    items+= '"'+ ii+ ': '+ data[ii][0]+ '"';
  }
  // assemble the command and the execute it with eval()
  var command= 'app.popUpMenu( '+ items+ ' );';
  var selection= eval( command );
  if( selection== null ) {
    return; // exit
  }

  // the user made a selection; parse out its index and use it
  // to access the bookmark record
  var index= 0;
  // toString() converts the String object to a string literal
  // eval() converts the string literal to a number
  index= eval( selection.substring( 0, selection.indexOf(':') ).toString() );
  if( index< data.length ) {
    try {
      // the document must be 'disclosed' for us to have any access
      // to its properties, so we use these FirstPage NextPage calls
      //
      app.openDoc( data[index][1] );
      app.execMenuItem( "FirstPage" );
      for( ii= 0; ii< data[index][2]; ++ii ) {
        app.execMenuItem( "NextPage" );
      }
    }
    catch( ee ) {
      var response=
        app.alert("打开书签错误. 是否删除本书签?", 2, 2,"删除书签");
      if( response== 4 && index< data.length ) {
        data.splice( index, 1 );
        SaveData( data );
      }
    }
  }
}

function DropBookmark() {
  // modelled after ShowBookmarks()
  var data= GetData();
  var items= '';
  for( ii= 0; ii< data.length; ++ii ) {
    if( ii!= 0 )
      items+= ', ';
    items+= '"'+ ii+ ': '+ data[ii][0]+ '"';
  }
  var command= 'app.popUpMenu( '+ items+ ' );';
  var selection= eval( command );
  if( selection== null ) {
    return; // exit
  }

  var index= 0;
  index= eval( selection.substring( 0, selection.indexOf(':') ).toString() );
  if( index< data.length ) {
    data.splice( index, 1 );
    SaveData( data );
  }
}

function ClearBookmarks() {
  if( app.alert("确认要清除所有的书签吗?", 2, 2,"删除书签" )== 4 ) {
    SaveData( new Array(0) );
  }
}

app.addMenuItem( {
cName: "-",              // menu divider
cParent: "View",         // append to the View menu
cExec: "void(0);" } );

app.addMenuItem( {
cName: "设置本页为书签(&B)",
cParent: "View",
cExec: "AddBookmark();",
cEnable: "event.rc= (event.target != null);" } );

app.addMenuItem( {
cName: "转到指定书签(&T)",
cParent: "View",
cExec: "ShowBookmarks();",
cEnable: "event.rc= (event.target != null);" } );
//cEnable: "event.rc= true;" } );

app.addMenuItem( {
cName: "删除一个书签(&D)",
cParent: "View",
cExec: "DropBookmark();",
cEnable: "event.rc= (event.target != null);" } );

app.addMenuItem( {
cName: "清除所有书签(&C)",
cParent: "View",
cExec: "ClearBookmarks();",
cEnable: "event.rc= true;" } );
分享到:
评论

相关推荐

    javascript pdf阅读器

    JavaScript PDF阅读器是一种基于Web的解决方案,它允许用户在浏览器中直接查看PDF文档,而无需安装额外的软件或插件。这种技术对于提供方便、快速的在线服务特别有用,尤其适用于那些希望在网页上分享文档但又不希望...

    JavaScript PDF阅读器.zip

    5. **交互功能**:JavaScript PDF阅读器通常还提供诸如缩放、书签、高亮、注释等交互功能。这些功能通过监听用户的鼠标和键盘事件,调用PDF.js提供的API来实现。 6. **性能优化**:由于PDF文件可能很大,PDF.js会...

    PDF添加书签javascript代码

    虽然这个示例是针对Adobe Reader 8.0的,但类似的逻辑可以应用于其他支持JavaScript的PDF阅读器,只需适应不同版本的API和用户界面。通过这种方式,你可以根据自己的需求定制PDF阅读环境,使得阅读和导航大型文档变...

    VC++pdf 阅读器

    在IT领域,特别是软件开发中,VC++ PDF阅读器是一个重要的工具,用于在Windows环境中查看和处理PDF(Portable Document Format)文件。PDF是一种普遍使用的文件格式,它能保持文档的原始布局和样式,使得信息交流...

    pdf阅读器自定义书签工具

    在PDF阅读器中,JavaScript常被用来增强交互性和功能性,比如实现动态书签的添加、删除和修改。这个脚本可能定义了与书签操作相关的函数和逻辑,如监听用户的交互事件,更新书签列表,以及在PDF文档中定位书签所指向...

    javaFx Pdf 阅读器

    7. **安全性**:考虑到PDF文件可能包含恶意代码,JavaFX PDF阅读器还需要实现安全机制,防止执行潜在的危险操作,例如防止JavaScript执行或者限制不安全的链接点击。 8. **用户体验**:优秀的PDF阅读器不仅要能正确...

    简单实用的PDF阅读器

    在本主题中,我们将深入探讨“简单实用的PDF阅读器”的相关知识点。 1. PDF文件的基本概念:PDF是一种由Adobe Systems公司开发的文件格式,它能够准确地保留原始文档的格式和内容,包括字体、图像和布局。这种格式...

    ios pdf阅读器

    在iOS平台上,开发一款PDF阅读器是一个常见的需求,特别是在Xcode 4.4及更高版本中,开发者可以利用内置的WebKit框架和UIWebView组件来实现这一功能。UIWebView是iOS SDK提供的一种轻量级的浏览器控件,它可以加载并...

    asp.net PDF阅读器源码

    3. **交互功能**:一个完整的PDF阅读器可能还需要提供一些交互功能,如缩放、平移、书签、搜索、高亮等。这些功能可以通过JavaScript在前端实现,与后端C#服务进行交互,获取必要的PDF信息。 4. **安全性**:处理...

    李炎恢JavaScript-PDF

    9. **跨平台兼容性**:由于不同的浏览器和PDF阅读器可能对JavaScript的支持程度不同,开发者需要考虑兼容性问题,确保代码能在多种环境下正常工作。 10. **性能优化**:处理PDF文件可能涉及大量的计算和资源消耗,...

    7款最佳jQuery和JavaScript的PDF查看器插件

    在Web开发中,PDF查看器插件对于那些需要在网站上展示PDF内容的开发者来说至关重要,例如在线文档共享、电子书阅读平台等。jQuery和JavaScript是两种常用的前端开发语言,它们能够提供动态和交互性的用户体验。 ...

    html5网页pdf查看器_在线pdf阅读器下载

    HTML5网页PDF查看器是一种基于Web技术实现的PDF文档预览和阅读工具,它允许用户在浏览器中直接打开和查看PDF文件,而无需依赖任何桌面应用程序。这种技术的出现极大地提升了网页的交互性和用户体验,特别是在处理...

    在线PDF阅读器(实例代码和插件)B/S

    4. 用户交互:在线阅读器需要提供类似于本地PDF阅读器的功能,如缩放、翻页、搜索、书签等。这些功能可以通过JavaScript实现,与后端服务配合完成。 三、实例代码分析 在"PDFView_Web"这个项目中,我们可以看到...

    PDF文档阅读器

    2. **阅读器功能**:基本的PDF阅读器提供浏览、搜索、放大缩小、旋转页面、书签管理等功能。高级阅读器可能还包括注释工具(如高亮、划线、添加文字)、表单填写、数字签名、页面组织等。 3. **Adobe Acrobat ...

    uniapp预览pdf的相关文件;pdf阅读器

    在uniapp中预览PDF,我们需要一个PDF阅读器组件或者服务。尽管uniapp本身并不直接支持PDF预览,但我们可以借助第三方库或插件来实现这一功能。 一种常见的方式是使用HTML5的`&lt;iframe&gt;`标签或者Web组件来嵌入PDF文件...

    PDF格式的阅读器

    以下是对PDF阅读器及其相关知识点的详细解释: 1. **PDF的起源与特性** - PDF最初由Adobe Systems开发,旨在解决电子文档在不同平台间的兼容性问题。 - PDF文件可以包含文本、图像、超链接、表格、图形、注释、...

    迷你版PDF阅读器

    迷你版PDF阅读器是一款小巧而实用的软件工具,专为那些希望在不占用大量系统资源的情况下,轻松查看PDF文档的用户设计。与市面上常见的大型PDF阅读器相比,它以其轻便、快速和简洁的界面赢得了用户的青睐。这款阅读...

    html5手机网页PDF文件阅读器插件

    通过结合使用PDF.js,开发者可以创建一个具有高级特性的PDF阅读器,比如平滑滚动、双页视图、文本选择和书签。 在手机网页上,考虑到移动设备的性能和屏幕大小,优化用户体验尤为重要。这可能包括适配不同的屏幕...

    开源的pdf阅读器源码

    2. UI设计:PDF阅读器的界面设计包括页面导航、缩放、旋转、书签、搜索等功能。这些功能的实现需要对Android的UI组件有深入理解,如RecyclerView用于展示书签,GestureDetector和ScaleGestureDetector用于捕捉用户的...

Global site tag (gtag.js) - Google Analytics