国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

javascript - Angular controlller控制域和原生js的關(guān)系

瀏覽:121日期:2024-03-08 15:12:36

問題描述

寫了一段js代碼,發(fā)現(xiàn)在controller里寫的原生js都不管用,報錯顯示無法找到該函數(shù),代碼如下所示:

app.controller(’orderFormCtrl’, function ($scope, $http) { // 訂單備注 $scope.food_remarks = []; // 訂單詳情數(shù)組 $scope.forms_detail = []; $scope.food_detail = []; // 查詢訂單詳情 $scope.search_detail = function(index){ $scope.forms_detail = $scope.food_forms[index];$scope.food_remarks = $scope.food_forms[index].remarks;console.log($scope.forms_detail);// var form_num = $scope.forms_detail.order_number;$scope.food_detail = $scope.food_forms[index].food_detail;// console.log($scope.food_detail);for (var i = 0; i < $scope.food_detail.length; i++) { for (var j = 0; j < $scope.food_menu.length; j++) {if ($scope.food_detail[i].id == $scope.food_menu[j].id) { $scope.food_detail[i].name = $scope.food_menu[j].name; $scope.food_detail[i].price = $scope.food_menu[j].price; $scope.food_detail[i].img = $scope.food_menu[j].img;} }} }; //計算總價 $scope.allSum=function(){ var allPrice = 0; for(var i= 0;i<$scope.food_detail.length;i++){ allPrice+=$scope.food_detail[i].price*$scope.food_detail[i].num; // console.log(allPrice);} return allPrice; };var LODOP; //聲明為全局變量 function printPreview(){ //創(chuàng)建小票打印頁 CreatePrintPage(); //打印預(yù)覽 LODOP.PREVIEW(); } /** * 樣例函數(shù),服務(wù)器確認訂單后執(zhí)行 */ function printOrder() {//創(chuàng)建小票打印頁 CreatePrintPage(); //開始打印 LODOP.PRINT(); } function CreatePrintPage(json) { //json 創(chuàng)建模擬服務(wù)器響應(yīng)的訂單信息對象 var json = {'title':'XXXXX訂單信息', 'name':'張三', 'phone': '138123456789', 'orderTime': '2012-10-11 15:30:15', 'orderNo': '20122157481315', 'shop':'XX連鎖', 'total':25.10,'totalCount':6, 'goodsList':[ {'name':'菜心(無公害食品)', 'price':5.00, 'count':2, 'total':10.08}, {'name':'菜心(無公害食品)', 'price':5.00, 'count':2, 'total':10.02}, {'name':'旺菜', 'price':4.50, 'count':1, 'total':4.50}, {'name':'黃心番薯(有機食品)', 'price':4.50, 'count':1, 'total':4.50} ] } var hPos=10,//小票上邊距 pageWidth=580,//小票寬度 rowHeight=15,//小票行距 //獲取控件對象 LODOP=getLodop(document.getElementById(’LODOP_OB’),document.getElementById(’LODOP_EM’)); //初始化 LODOP.PRINT_INIT('打印控件功能演示_Lodop功能_名片'); //添加小票標(biāo)題文本 LODOP.ADD_PRINT_TEXT(hPos,30,pageWidth,rowHeight,json.title); //上邊距往下移 hPos+=rowHeight; LODOP.ADD_PRINT_TEXT(hPos,1,pageWidth,rowHeight,'姓名:'); LODOP.ADD_PRINT_TEXT(hPos,30,pageWidth,rowHeight,json.name); //hPos+=rowHeight; //電話不換行 LODOP.ADD_PRINT_TEXT(hPos,70,pageWidth,rowHeight,'電話:'); LODOP.ADD_PRINT_TEXT(hPos,100,pageWidth,rowHeight,json.phone); hPos+=rowHeight; LODOP.ADD_PRINT_TEXT(hPos,1,pageWidth,rowHeight,'下單時間:'); LODOP.ADD_PRINT_TEXT(hPos,60,pageWidth,rowHeight,json.orderTime); hPos+=rowHeight; LODOP.ADD_PRINT_TEXT(hPos,1,pageWidth,rowHeight,'訂單編號:'); LODOP.ADD_PRINT_TEXT(hPos,60,pageWidth,rowHeight,json.orderNo); hPos+=rowHeight; LODOP.ADD_PRINT_TEXT(hPos,1,pageWidth,rowHeight,'取貨門店:'); LODOP.ADD_PRINT_TEXT(hPos,60,pageWidth,rowHeight,json.shop); hPos+=rowHeight; LODOP.ADD_PRINT_LINE(hPos,2, hPos, pageWidth,2, 1); hPos+=5; LODOP.ADD_PRINT_TEXT(hPos,1,pageWidth,rowHeight,'商品名稱'); LODOP.ADD_PRINT_TEXT(hPos,70,pageWidth,rowHeight,'單價'); LODOP.ADD_PRINT_TEXT(hPos,110,pageWidth,rowHeight,'數(shù)量'); LODOP.ADD_PRINT_TEXT(hPos,140,pageWidth,rowHeight,'小計'); hPos+=rowHeight; //遍歷json的商品數(shù)組 for(var i=0;i<json.goodsList.length;i++){ if(json.goodsList[i].name.length<4){ LODOP.ADD_PRINT_TEXT(hPos,1,pageWidth,rowHeight,json.goodsList[i].name); }else { //商品名字過長,其他字段需要換行 LODOP.ADD_PRINT_TEXT(hPos,1,pageWidth,rowHeight,json.goodsList[i].name); hPos+=rowHeight; } LODOP.ADD_PRINT_TEXT(hPos,70,pageWidth,rowHeight,json.goodsList[i].price); LODOP.ADD_PRINT_TEXT(hPos,115,pageWidth,rowHeight,json.goodsList[i].count); LODOP.ADD_PRINT_TEXT(hPos,140,pageWidth,rowHeight,json.goodsList[i].total); hPos+=rowHeight; } //商品遍歷打印完畢,空一行 hPos+=rowHeight; //合計 LODOP.ADD_PRINT_TEXT(hPos,80,pageWidth,rowHeight,'合計:'+json.totalCount); LODOP.ADD_PRINT_TEXT(hPos,130,pageWidth,rowHeight,'¥'+json.total); hPos+=rowHeight; LODOP.ADD_PRINT_TEXT(hPos,2,pageWidth,rowHeight,(new Date()).toLocaleDateString()+' '+(new Date()).toLocaleTimeString()) hPos+=rowHeight; LODOP.ADD_PRINT_TEXT(hPos,25,pageWidth,rowHeight,'謝謝惠顧,歡迎下次光臨!'); //初始化打印頁的規(guī)格 LODOP.SET_PRINT_PAGESIZE(3,pageWidth,45,'XXXXX訂單信息');} });

后來發(fā)現(xiàn)如果把原生js放到controller的控制域外就可以找到該函數(shù),并且可以正常運行(如下)

app.controller(’orderFormCtrl’, function ($scope, $http) { // 訂單備注 $scope.food_remarks = []; // 訂單詳情數(shù)組 $scope.forms_detail = []; $scope.food_detail = []; // 查詢訂單詳情 $scope.search_detail = function(index){ $scope.forms_detail = $scope.food_forms[index];$scope.food_remarks = $scope.food_forms[index].remarks;console.log($scope.forms_detail);// var form_num = $scope.forms_detail.order_number;$scope.food_detail = $scope.food_forms[index].food_detail;// console.log($scope.food_detail);for (var i = 0; i < $scope.food_detail.length; i++) { for (var j = 0; j < $scope.food_menu.length; j++) {if ($scope.food_detail[i].id == $scope.food_menu[j].id) { $scope.food_detail[i].name = $scope.food_menu[j].name; $scope.food_detail[i].price = $scope.food_menu[j].price; $scope.food_detail[i].img = $scope.food_menu[j].img;} }} }; //計算總價 $scope.allSum=function(){ var allPrice = 0; for(var i= 0;i<$scope.food_detail.length;i++){ allPrice+=$scope.food_detail[i].price*$scope.food_detail[i].num; // console.log(allPrice);} return allPrice; }; });//controller控制域外var LODOP; //聲明為全局變量 function printPreview(){ //創(chuàng)建小票打印頁 CreatePrintPage(); //打印預(yù)覽 LODOP.PREVIEW(); } /** * 樣例函數(shù),服務(wù)器確認訂單后執(zhí)行 */ function printOrder() {//創(chuàng)建小票打印頁 CreatePrintPage(); //開始打印 LODOP.PRINT(); } function CreatePrintPage(json) { //json 創(chuàng)建模擬服務(wù)器響應(yīng)的訂單信息對象 var json = {'title':'XXXXX訂單信息', 'name':'張三', 'phone': '138123456789', 'orderTime': '2012-10-11 15:30:15', 'orderNo': '20122157481315', 'shop':'XX連鎖', 'total':25.10,'totalCount':6, 'goodsList':[ {'name':'菜心(無公害食品)', 'price':5.00, 'count':2, 'total':10.08}, {'name':'菜心(無公害食品)', 'price':5.00, 'count':2, 'total':10.02}, {'name':'旺菜', 'price':4.50, 'count':1, 'total':4.50}, {'name':'黃心番薯(有機食品)', 'price':4.50, 'count':1, 'total':4.50} ] } var hPos=10,//小票上邊距 pageWidth=580,//小票寬度 rowHeight=15,//小票行距 //獲取控件對象 LODOP=getLodop(document.getElementById(’LODOP_OB’),document.getElementById(’LODOP_EM’)); //初始化 LODOP.PRINT_INIT('打印控件功能演示_Lodop功能_名片'); //添加小票標(biāo)題文本 LODOP.ADD_PRINT_TEXT(hPos,30,pageWidth,rowHeight,json.title); //上邊距往下移 hPos+=rowHeight; LODOP.ADD_PRINT_TEXT(hPos,1,pageWidth,rowHeight,'姓名:'); LODOP.ADD_PRINT_TEXT(hPos,30,pageWidth,rowHeight,json.name); //hPos+=rowHeight; //電話不換行 LODOP.ADD_PRINT_TEXT(hPos,70,pageWidth,rowHeight,'電話:'); LODOP.ADD_PRINT_TEXT(hPos,100,pageWidth,rowHeight,json.phone); hPos+=rowHeight; LODOP.ADD_PRINT_TEXT(hPos,1,pageWidth,rowHeight,'下單時間:'); LODOP.ADD_PRINT_TEXT(hPos,60,pageWidth,rowHeight,json.orderTime); hPos+=rowHeight; LODOP.ADD_PRINT_TEXT(hPos,1,pageWidth,rowHeight,'訂單編號:'); LODOP.ADD_PRINT_TEXT(hPos,60,pageWidth,rowHeight,json.orderNo); hPos+=rowHeight; LODOP.ADD_PRINT_TEXT(hPos,1,pageWidth,rowHeight,'取貨門店:'); LODOP.ADD_PRINT_TEXT(hPos,60,pageWidth,rowHeight,json.shop); hPos+=rowHeight; LODOP.ADD_PRINT_LINE(hPos,2, hPos, pageWidth,2, 1); hPos+=5; LODOP.ADD_PRINT_TEXT(hPos,1,pageWidth,rowHeight,'商品名稱'); LODOP.ADD_PRINT_TEXT(hPos,70,pageWidth,rowHeight,'單價'); LODOP.ADD_PRINT_TEXT(hPos,110,pageWidth,rowHeight,'數(shù)量'); LODOP.ADD_PRINT_TEXT(hPos,140,pageWidth,rowHeight,'小計'); hPos+=rowHeight; //遍歷json的商品數(shù)組 for(var i=0;i<json.goodsList.length;i++){ if(json.goodsList[i].name.length<4){ LODOP.ADD_PRINT_TEXT(hPos,1,pageWidth,rowHeight,json.goodsList[i].name); }else { //商品名字過長,其他字段需要換行 LODOP.ADD_PRINT_TEXT(hPos,1,pageWidth,rowHeight,json.goodsList[i].name); hPos+=rowHeight; } LODOP.ADD_PRINT_TEXT(hPos,70,pageWidth,rowHeight,json.goodsList[i].price); LODOP.ADD_PRINT_TEXT(hPos,115,pageWidth,rowHeight,json.goodsList[i].count); LODOP.ADD_PRINT_TEXT(hPos,140,pageWidth,rowHeight,json.goodsList[i].total); hPos+=rowHeight; } //商品遍歷打印完畢,空一行 hPos+=rowHeight; //合計 LODOP.ADD_PRINT_TEXT(hPos,80,pageWidth,rowHeight,'合計:'+json.totalCount); LODOP.ADD_PRINT_TEXT(hPos,130,pageWidth,rowHeight,'¥'+json.total); hPos+=rowHeight; LODOP.ADD_PRINT_TEXT(hPos,2,pageWidth,rowHeight,(new Date()).toLocaleDateString()+' '+(new Date()).toLocaleTimeString()) hPos+=rowHeight; LODOP.ADD_PRINT_TEXT(hPos,25,pageWidth,rowHeight,'謝謝惠顧,歡迎下次光臨!'); //初始化打印頁的規(guī)格 LODOP.SET_PRINT_PAGESIZE(3,pageWidth,45,'XXXXX訂單信息');}

javascript - Angular controlller控制域和原生js的關(guān)系

請問這是什么原因造成的呢?之前做過的一個項目在controller中寫原生的js也是可以用的啊,不知道這次為什么不可以

問題解答

回答1:

基礎(chǔ)性問題。

當(dāng)在 use strict 模式下,function 應(yīng)該遵循先定義后使用

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 伊人22综合| 欧美经典成人在观看线视频 | 国产精品欧美激情在线播放 | 麻豆国产96在线 | 日韩 | 亚洲成人手机在线观看 | 91情侣高清精品国产 | 国自产精品手机在线视频香蕉 | 加勒比色 | 中国国产一国产一级毛片视频 | 韩国欧洲一级毛片免费 | 99草精品视频 | 国产成人精品aaaa视频一区 | 国产精品日本欧美一区二区 | 无遮挡一级毛片私人影院 | 国产日韩精品视频一区二区三区 | 日本一级全黄大片 | 九草视频| 99在线国产视频 | 日韩国产在线观看 | 一级白嫩美女毛片免费 | 日本三级在线观看中文字 | 亚洲国产欧美一区 | 草草影院在线播放 | 国产成人mv 在线播放 | 国产精品成人观看视频国产 | 亚洲欧美精品国产一区色综合 | 久久女同互慰一区二区三区 | 免费欧美黄色 | 最近韩国日本免费免费版 | 久久免费香蕉视频 | 手机在线免费看毛片 | 日本综合欧美一区二区三区 | 国产欧美另类久久精品91 | 香港三澳门三日本三级 | 欧美高清性色生活 | 国产亚洲一区呦系列 | 国产一区二区亚洲精品 | 手机在线亚洲 | 国产一区亚洲二区 | 俄罗斯a级毛片 | 日本高清视频在线观看 |